
:root{
  --black:#111111;
  --charcoal:#181b20;
  --navy:#002f4f;
  --deep-navy:#02263f;
  --marlins-blue:#005a7c;
  --aqua:#12a9cf;
  --ice:#f5f8fa;
  --silver:#d9dde0;
  --white:#ffffff;
  --red:#b30d17;
  --muted:#b9c8d2;
  --line:rgba(255,255,255,.14);
  --card:#0a2436;
}
*{box-sizing:border-box} body{margin:0;background:#061727;color:var(--white);font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif} a{text-decoration:none;color:inherit}
.top-strip{height:42px;background:#02101d;display:flex;gap:22px;align-items:center;padding:0 5vw;font-size:13px;text-transform:uppercase;font-weight:800;letter-spacing:.06em;color:#dceaf3;border-bottom:1px solid var(--line)}
.top-strip span{color:var(--teal)}
.main-nav{position:sticky;top:0;z-index:50;background:rgba(6,23,39,.96);backdrop-filter:blur(14px);display:flex;justify-content:space-between;align-items:center;padding:18px 5vw;border-bottom:1px solid var(--line)}
.brand{display:flex;gap:14px;align-items:center}.brand strong{font-size:24px;letter-spacing:-.04em}.brand span{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;font-weight:800;letter-spacing:.12em}
.logo{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--teal),var(--orange));color:#00111f;font-weight:1000}
.nav-links{display:flex;gap:22px;align-items:center;text-transform:uppercase;font-size:13px;font-weight:900;letter-spacing:.08em}.nav-links a:hover{color:var(--orange)}.nav-toggle{display:none;background:none;border:0;color:white;font-size:30px}


.hero{min-height:660px;position:relative;padding:80px 5vw;display:grid;align-items:end;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:linear-gradient(90deg,rgba(6,23,39,.95),rgba(6,23,39,.55)),url('../assets/marlins-hero.svg') center/cover no-repeat;filter:saturate(1.1)}
.hero-grid{position:relative;display:grid;grid-template-columns:1.2fr .45fr;gap:28px;align-items:end}.hero-copy{max-width:900px}
.kicker{color:var(--teal);text-transform:uppercase;font-size:13px;font-weight:1000;letter-spacing:.16em} h1{font-size:clamp(48px,8vw,110px);line-height:.88;margin:10px 0 18px;letter-spacing:-.08em} h2{font-size:clamp(30px,4vw,54px);line-height:.98;margin:8px 0 16px;letter-spacing:-.06em}.lead{color:#dceaf3;font-size:22px;line-height:1.45;max-width:780px}
.button-row{display:flex;gap:14px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:14px 20px;font-weight:1000;text-transform:uppercase;font-size:13px;letter-spacing:.08em}.btn.orange{background:var(--orange)}.btn.ghost{border:1px solid var(--line);background:rgba(255,255,255,.08)}
.record-card{background:#f7fbff;color:#061727;border-radius:24px;padding:28px;box-shadow:0 20px 80px rgba(0,0,0,.36)}.record-card span{text-transform:uppercase;font-size:12px;font-weight:1000;color:var(--blue);letter-spacing:.14em}.record-card strong{display:block;font-size:86px;line-height:1;color:var(--orange);letter-spacing:-.08em}.record-card p{font-weight:900}
.page{padding:58px 5vw}.inner{min-height:70vh}.section-head{display:flex;justify-content:space-between;align-items:end;gap:20px;margin-bottom:22px}.section-head a{color:var(--orange);font-weight:1000}.schedule-rail{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.game-card{background:linear-gradient(180deg,#103653,#0b263a);border:1px solid var(--line);border-radius:20px;padding:22px}.game-card span{color:var(--orange);text-transform:uppercase;font-size:12px;font-weight:1000}.game-card h3{font-size:28px;margin:8px 0}.game-card small{color:var(--muted)}
.content-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:22px;margin:60px 0}.feature-story{background:white;color:#061727;border-radius:24px;overflow:hidden;display:grid;grid-template-columns:.8fr 1fr}.image-panel{min-height:360px;background:url('../assets/story-placeholder.svg') center/cover no-repeat}.story-text{padding:30px}.story-text a{color:var(--orange);font-weight:1000}.headlines{background:#092033;border:1px solid var(--line);border-radius:24px;padding:24px}.headlines a{display:block;padding:16px 0;border-top:1px solid var(--line);font-weight:900}.headlines span,.news-list span{display:inline-grid;place-items:center;background:var(--orange);color:white;border-radius:6px;padding:4px 6px;margin-right:8px;font-size:11px}
.quick-links{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:40px 0}.quick-links a{min-height:110px;display:grid;place-items:center;text-align:center;background:#0a2740;border:1px solid var(--line);border-radius:18px;text-transform:uppercase;font-weight:1000;letter-spacing:.08em}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.gallery-grid.large{grid-template-columns:repeat(3,1fr)}.gallery-grid article{min-height:190px;display:flex;align-items:flex-end;padding:22px;border-radius:20px;border:1px solid var(--line);font-size:24px;font-weight:1000;background:linear-gradient(135deg,rgba(0,184,200,.32),rgba(241,90,36,.25))}
.page-title{max-width:900px;margin-bottom:30px}.page-title p:not(.kicker){color:#d8e7f0;font-size:19px;line-height:1.5}.integration-banner{background:#fff;color:#061727;border-radius:18px;padding:20px;margin-bottom:20px}.table-card{overflow:auto;background:#092033;border:1px solid var(--line);border-radius:20px}table{width:100%;border-collapse:collapse;min-width:780px}th,td{padding:16px;border-bottom:1px solid var(--line);text-align:left}th{color:var(--teal);text-transform:uppercase;font-size:12px;letter-spacing:.14em}td a{color:var(--orange);font-weight:900}
.player-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.player{background:#092033;border:1px solid var(--line);border-radius:22px;padding:20px}.player-photo{height:190px;border-radius:18px;background:linear-gradient(135deg,var(--teal),var(--blue));display:grid;place-items:center;font-size:44px;font-weight:1000;margin-bottom:16px}.player span{color:var(--orange);font-weight:1000}.player h3{font-size:22px;margin:8px 0 4px}.player p{color:var(--muted)}
.stat-leaders,.sponsor-grid,.contact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:24px}.stat-leaders article,.sponsor-grid article,.contact-grid a,.form-placeholder,.news-list article{background:#092033;border:1px solid var(--line);border-radius:22px;padding:24px}.stat-leaders span{color:var(--teal);text-transform:uppercase;font-weight:1000;font-size:12px;letter-spacing:.14em}.stat-leaders strong,.sponsor-grid strong{display:block;font-size:48px;color:var(--orange);letter-spacing:-.06em}.sponsor-grid .featured{border-color:var(--orange);transform:translateY(-8px)}.contact-grid{grid-template-columns:repeat(3,1fr)}.contact-grid span{display:block;color:var(--teal);text-transform:uppercase;font-size:12px;font-weight:1000}.contact-grid strong{font-size:22px}.news-list{display:grid;gap:18px}
.footer{display:flex;justify-content:space-between;gap:24px;align-items:center;border-top:1px solid var(--line);background:#020d17;padding:36px 5vw;color:#c8d8e2}.footer-brand{display:flex;gap:14px;align-items:center}.footer p{margin:.25rem 0 0;color:var(--muted)}.footer-links{display:flex;gap:18px;flex-wrap:wrap;font-weight:900;color:white}
@media(max-width:1000px){.nav-toggle{display:block}.nav-links{display:none;position:absolute;left:0;right:0;top:91px;flex-direction:column;align-items:flex-start;background:#061727;padding:20px 5vw}.nav-links.open{display:flex}.hero-grid,.content-grid,.feature-story{grid-template-columns:1fr}.schedule-rail,.quick-links,.gallery-grid,.gallery-grid.large,.player-grid,.stat-leaders,.sponsor-grid,.contact-grid{grid-template-columns:1fr 1fr}.record-card strong{font-size:62px}}
@media(max-width:640px){.top-strip{display:none}.brand strong{font-size:18px}.logo{width:44px;height:44px}.hero{min-height:560px}.schedule-rail,.quick-links,.gallery-grid,.gallery-grid.large,.player-grid,.stat-leaders,.sponsor-grid,.contact-grid{grid-template-columns:1fr}.section-head,.footer{display:block}.feature-story{display:block}}


/* === Logo-integrated clean Marlins theme overrides === */
body{
  background:
    radial-gradient(circle at 18% 0%, rgba(18,169,207,.24), transparent 34%),
    linear-gradient(180deg, #061724 0%, #07131c 48%, #0b0d10 100%);
}
.top-strip{
  background:#0a0d10;
  color:var(--ice);
  border-bottom:1px solid rgba(255,255,255,.10);
}
.top-strip span{color:var(--aqua)}
.main-nav{
  background:rgba(8,14,19,.94);
  border-bottom:1px solid rgba(255,255,255,.12);
  box-shadow:0 12px 35px rgba(0,0,0,.28);
}
.brand{min-width:280px}
.site-logo{
  width:76px;
  height:76px;
  object-fit:contain;
  border-radius:0;
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.35));
  background:rgba(255,255,255,.96);
  padding:7px;
}
.footer-logo{
  width:72px;
  height:72px;
  object-fit:contain;
  background:#fff;
  border-radius:14px;
  padding:6px;
}
.brand strong{
  color:#fff;
  text-shadow:0 2px 14px rgba(0,0,0,.55);
}
.brand span{color:#d4e5ee}
.nav-links a{
  padding:10px 2px;
  border-bottom:2px solid transparent;
}
.nav-links a:hover{
  color:var(--aqua);
  border-bottom-color:var(--aqua);
}
.hero{
  background:linear-gradient(135deg,#081018 0%, #082a42 46%, #0b0d10 100%);
}
.logo-hero{
  min-height:690px;
}
.hero-bg{
  background:
    linear-gradient(90deg,rgba(6,13,19,.94),rgba(6,13,19,.68),rgba(6,13,19,.92)),
    url('../assets/marlins-hero.svg') center/cover no-repeat !important;
}
.hero-wordmark{
  max-width:560px;
  width:100%;
  background:rgba(255,255,255,.96);
  border-radius:26px;
  padding:18px 22px;
  margin-bottom:26px;
  box-shadow:0 26px 80px rgba(0,0,0,.34);
}
.kicker{
  color:var(--aqua);
}
h1,h2{
  color:#fff;
}
.lead{color:#e3eef4}
.btn.orange{
  background:linear-gradient(135deg,var(--marlins-blue),var(--aqua));
  color:#fff;
  box-shadow:0 14px 35px rgba(18,169,207,.22);
}
.btn.ghost{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.22);
}
.record-card{
  background:linear-gradient(180deg,#ffffff,#edf4f7);
  border:1px solid rgba(255,255,255,.72);
}
.league-card img{
  width:100%;
  max-width:240px;
  display:block;
  margin:0 auto 18px;
  object-fit:contain;
}
.record-card span{color:var(--marlins-blue)}
.record-card strong{color:var(--red)}
.game-card,.headlines,.player,.stat-leaders article,.sponsor-grid article,.contact-grid a,.form-placeholder,.news-list article,.table-card{
  background:linear-gradient(180deg,rgba(8,45,70,.92),rgba(5,22,34,.94));
  border:1px solid rgba(255,255,255,.13);
}
.game-card span,.section-head a,.story-text a,td a,.player span{
  color:var(--aqua);
}
.quick-links a{
  background:linear-gradient(135deg,rgba(0,90,124,.95),rgba(12,31,45,.95));
}
.gallery-grid article{
  background:
    linear-gradient(135deg,rgba(0,90,124,.78),rgba(17,17,17,.72)),
    url('../assets/story-placeholder.svg') center/cover no-repeat;
}
.feature-story{
  background:#f7fbff;
}
.story-text h2{
  color:#07131c;
}
.player-photo{
  background:
    radial-gradient(circle at top left,rgba(255,255,255,.75),transparent 32%),
    linear-gradient(135deg,var(--aqua),var(--marlins-blue) 52%,var(--black));
  color:#fff;
}
.stat-leaders strong,.sponsor-grid strong{
  color:var(--aqua);
}
.sponsor-grid .featured{
  border-color:var(--aqua);
}
.mabl-inline{
  width:96px;
  max-height:44px;
  object-fit:contain;
  background:#fff;
  border-radius:8px;
  padding:3px 5px;
  vertical-align:middle;
  margin-right:8px;
}
.footer{
  background:#080d12;
}
.footer-links a:hover{color:var(--aqua)}
@media(max-width:1000px){
  .site-logo{width:60px;height:60px}
  .brand{min-width:0}
  .hero-wordmark{max-width:440px}
}
@media(max-width:640px){
  .site-logo{width:52px;height:52px}
  .brand strong{font-size:16px}
  .hero-wordmark{border-radius:18px;padding:12px}
}


/* === Cleaner UF-style Marlins theme: white content, black nav, teal accents === */
:root{
  --black:#07090b;
  --charcoal:#111418;
  --teal:#009fc3;
  --teal-dark:#007997;
  --teal-soft:#e8f8fb;
  --white:#ffffff;
  --offwhite:#f5f7f8;
  --silver:#d9e1e5;
  --text:#111820;
  --muted-text:#5d6b75;
  --line-light:#dce5ea;
  --red:#b30d17;
}

body{
  background:var(--offwhite) !important;
  color:var(--text) !important;
}

.top-strip{
  background:#07090b !important;
  color:#ffffff !important;
  border-bottom:1px solid rgba(255,255,255,.12) !important;
}

.top-strip span{
  color:var(--teal) !important;
}

.main-nav{
  background:#ffffff !important;
  color:var(--text) !important;
  border-bottom:1px solid var(--line-light) !important;
  box-shadow:0 10px 24px rgba(0,0,0,.08) !important;
}

.brand strong{
  color:#111820 !important;
  text-shadow:none !important;
}

.brand span{
  color:var(--muted-text) !important;
}

.site-logo{
  background:#ffffff !important;
  border:1px solid var(--line-light);
  box-shadow:0 6px 18px rgba(0,0,0,.08);
  filter:none !important;
}

.nav-links a{
  color:#111820 !important;
}

.nav-links a:hover{
  color:var(--teal) !important;
  border-bottom-color:var(--teal) !important;
}

.hero{
  background:#ffffff !important;
  color:var(--text) !important;
  min-height:610px !important;
  border-bottom:1px solid var(--line-light);
}

.hero-bg{
  background:
    linear-gradient(90deg,rgba(255,255,255,.95),rgba(255,255,255,.80),rgba(255,255,255,.55)),
    url('../assets/marlins-hero.svg') center/cover no-repeat !important;
  opacity:1 !important;
}

.hero-copy h1,
.page-title h1{
  color:var(--text) !important;
}

h1,h2,h3{
  color:var(--text) !important;
}

.lead,
.page-title p:not(.kicker){
  color:var(--muted-text) !important;
}

.hero-wordmark{
  background:#ffffff !important;
  border:1px solid var(--line-light);
  box-shadow:0 14px 38px rgba(0,0,0,.10) !important;
}

.kicker{
  color:var(--teal) !important;
}

.btn.orange{
  background:var(--teal) !important;
  color:#ffffff !important;
  box-shadow:0 10px 24px rgba(0,159,195,.22) !important;
}

.btn.ghost{
  background:#ffffff !important;
  color:var(--text) !important;
  border:1px solid var(--line-light) !important;
}

.record-card{
  background:#ffffff !important;
  color:var(--text) !important;
  border:1px solid var(--line-light) !important;
  box-shadow:0 16px 36px rgba(0,0,0,.10) !important;
}

.record-card strong{
  color:var(--teal) !important;
}

.page{
  background:var(--offwhite) !important;
}

.inner{
  background:
    linear-gradient(180deg,#ffffff 0%,#f5f7f8 100%) !important;
}

.events-results,
.media-section,
.content-grid{
  color:var(--text) !important;
}

.game-card,
.headlines,
.player,
.stat-leaders article,
.sponsor-grid article,
.contact-grid a,
.form-placeholder,
.news-list article,
.table-card{
  background:#ffffff !important;
  color:var(--text) !important;
  border:1px solid var(--line-light) !important;
  box-shadow:0 10px 28px rgba(0,0,0,.06) !important;
}

.game-card h3,
.game-card p,
.headlines h3,
.headlines a,
.player h3,
.news-list h2{
  color:var(--text) !important;
}

.game-card small,
.player p,
.news-list p{
  color:var(--muted-text) !important;
}

.game-card span,
.section-head a,
.story-text a,
td a,
.player span{
  color:var(--teal) !important;
}

.schedule-rail .game-card:first-child{
  border-top:4px solid var(--teal) !important;
}

.quick-links a{
  background:#ffffff !important;
  color:var(--text) !important;
  border:1px solid var(--line-light) !important;
  box-shadow:0 8px 22px rgba(0,0,0,.05) !important;
}

.quick-links a:hover{
  background:var(--teal-soft) !important;
  color:var(--teal-dark) !important;
}

.gallery-grid article{
  background:
    linear-gradient(135deg,rgba(0,159,195,.78),rgba(7,9,11,.62)),
    url('../assets/story-placeholder.svg') center/cover no-repeat !important;
  color:#ffffff !important;
}

.feature-story{
  background:#ffffff !important;
  color:var(--text) !important;
  border:1px solid var(--line-light);
  box-shadow:0 12px 32px rgba(0,0,0,.06);
}

.story-text h2{
  color:var(--text) !important;
}

.story-text p{
  color:var(--muted-text) !important;
}

.player-photo{
  background:
    radial-gradient(circle at top left,rgba(255,255,255,.45),transparent 34%),
    linear-gradient(135deg,var(--teal),#101820) !important;
  color:#ffffff !important;
}

.stat-leaders strong,
.sponsor-grid strong{
  color:var(--teal) !important;
}

.stat-leaders span{
  color:#111820 !important;
}

.sponsor-grid .featured{
  border-color:var(--teal) !important;
  border-top:5px solid var(--teal) !important;
}

table{
  background:#ffffff !important;
  color:var(--text) !important;
}

th{
  color:#111820 !important;
  background:#eef3f5 !important;
  border-bottom:1px solid var(--line-light) !important;
}

td{
  border-bottom:1px solid var(--line-light) !important;
  color:var(--text) !important;
}

.integration-banner{
  background:#ffffff !important;
  color:var(--text) !important;
  border-left:6px solid var(--teal);
  box-shadow:0 8px 24px rgba(0,0,0,.05);
}

.footer{
  background:#07090b !important;
  color:#ffffff !important;
  border-top:5px solid var(--teal) !important;
}

.footer p{
  color:#d5dde2 !important;
}

.footer-links a{
  color:#ffffff !important;
}

.footer-links a:hover{
  color:var(--teal) !important;
}

.footer-logo{
  background:#ffffff !important;
}

.mabl-inline{
  background:#ffffff !important;
}

@media(max-width:1000px){
  .nav-links{
    background:#ffffff !important;
    border-bottom:1px solid var(--line-light);
  }
}


/* === UF-style roster list page === */
.roster-page{
  background:#ffffff !important;
}
.roster-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:28px;
  align-items:start;
}
.roster-title h1{
  font-size:32px !important;
  letter-spacing:-.03em !important;
  border-left:5px solid var(--teal);
  padding-left:18px;
}
.roster-toolbar{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin:24px 0 28px;
}
.roster-toolbar button,
.roster-toolbar select,
.coach-jump{
  height:52px;
  border-radius:9px;
  border:1px solid var(--line-light);
  background:#ffffff;
  color:var(--text);
  font-weight:800;
  padding:0 16px;
}
.roster-toolbar button:first-child,
.roster-toolbar button:nth-child(2),
.view-type .active{
  background:var(--teal);
  color:#ffffff;
  border-color:var(--teal);
}
.roster-toolbar select{
  min-width:190px;
}
.coach-jump{
  display:inline-flex;
  align-items:center;
  background:#eef3f5;
}
.view-type{
  margin-left:auto;
  display:flex;
  align-items:center;
  gap:8px;
}
.view-type span{
  color:var(--muted-text);
  font-size:13px;
}
.roster-list{
  display:grid;
  gap:14px;
}
.roster-row{
  display:grid;
  grid-template-columns:minmax(360px,1fr) minmax(220px,.8fr) 120px;
  gap:20px;
  align-items:center;
  background:#ffffff;
  border:1px solid var(--line-light);
  border-radius:10px;
  box-shadow:0 7px 22px rgba(0,0,0,.04);
  overflow:hidden;
}
.roster-main{
  display:flex;
  align-items:center;
  gap:18px;
  padding:18px 24px;
}
.headshot{
  width:76px;
  height:76px;
  border-radius:50%;
  background:
    radial-gradient(circle at top left,rgba(255,255,255,.70),transparent 32%),
    linear-gradient(135deg,var(--teal),#101820);
  color:#ffffff;
  display:grid;
  place-items:center;
  font-weight:1000;
  font-size:23px;
  flex:0 0 auto;
  position:relative;
}
.headshot::after{
  content:"";
  position:absolute;
  right:-3px;
  bottom:2px;
  width:22px;
  height:22px;
  border-radius:50%;
  background:var(--teal);
  border:3px solid #fff;
}
.player-name{
  color:#003f5f;
  font-weight:1000;
  font-size:18px;
}
.player-name:hover{
  color:var(--teal);
}
.player-meta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin-top:7px;
  color:var(--muted-text);
  font-weight:800;
}
.player-meta span,
.player-meta strong{
  padding-right:10px;
  border-right:1px solid var(--line-light);
}
.player-meta span:last-child{
  border-right:0;
}
.roster-location{
  color:var(--text);
  line-height:1.35;
}
.roster-location span{
  font-size:14px;
}
.roster-location p{
  margin:4px 0 0;
  color:var(--muted-text);
}
.bio-link{
  color:#003f5f;
  font-weight:1000;
  padding-right:22px;
}
.bio-link:hover{
  color:var(--teal);
}
.related-news{
  background:#ffffff;
  border:1px solid var(--line-light);
  border-radius:10px;
  box-shadow:0 7px 22px rgba(0,0,0,.04);
  padding:24px;
  position:sticky;
  top:120px;
}
.related-news h2{
  font-size:22px;
  border-bottom:4px solid var(--teal);
  padding-bottom:12px;
  margin-bottom:20px;
}
.related-news article{
  display:grid;
  grid-template-columns:56px 1fr;
  gap:12px;
  padding:14px 0;
  border-bottom:1px solid var(--line-light);
}
.news-thumb{
  width:56px;
  height:56px;
  border-radius:8px;
  background:linear-gradient(135deg,var(--teal),#101820);
  color:#ffffff;
  display:grid;
  place-items:center;
  font-weight:1000;
}
.related-news article a{
  font-weight:1000;
  color:#003f5f;
  line-height:1.25;
}
.related-news article span{
  grid-column:2;
  color:var(--muted-text);
  font-size:13px;
}
.all-news{
  display:block;
  text-align:center;
  margin-top:18px;
  background:#003f5f;
  color:#ffffff;
  padding:14px;
  border-radius:6px;
  font-weight:1000;
}
.coaches-block{
  margin-top:34px;
}
.coaches-block h2{
  font-size:28px;
}
.player-profile-page{
  background:#ffffff !important;
}
.back-link{
  color:var(--teal);
  font-weight:1000;
}
.player-profile-hero{
  display:grid;
  grid-template-columns:180px 1fr;
  gap:28px;
  align-items:center;
  margin:28px 0;
  padding:34px;
  border:1px solid var(--line-light);
  border-radius:14px;
  background:#fff;
}
.profile-photo{
  width:180px;
  height:180px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--teal),#101820);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:54px;
  font-weight:1000;
}
.player-profile-hero h1{
  font-size:58px !important;
}
.profile-badges{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:12px 0;
}
.profile-badges span{
  background:var(--teal-soft);
  color:#003f5f;
  border:1px solid var(--line-light);
  padding:8px 12px;
  border-radius:999px;
  font-weight:1000;
}
.profile-grid{
  display:grid;
  grid-template-columns:1fr 420px;
  gap:22px;
}
.profile-grid article{
  background:#ffffff;
  border:1px solid var(--line-light);
  border-radius:14px;
  padding:24px;
}
@media(max-width:1100px){
  .roster-layout{
    grid-template-columns:1fr;
  }
  .related-news{
    position:static;
  }
  .roster-row{
    grid-template-columns:1fr;
    gap:0;
    padding-bottom:18px;
  }
  .roster-location,.bio-link{
    padding:0 24px 12px;
  }
  .view-type{
    margin-left:0;
  }
}
@media(max-width:650px){
  .roster-toolbar select{
    min-width:100%;
  }
  .roster-main{
    align-items:flex-start;
    padding:16px;
  }
  .headshot{
    width:62px;
    height:62px;
    font-size:18px;
  }
  .player-profile-hero,.profile-grid{
    grid-template-columns:1fr;
  }
  .profile-photo{
    width:140px;
    height:140px;
  }
  .player-profile-hero h1{
    font-size:38px !important;
  }
}


/* === UF-style individual player profile pages === */
.player-page-uf{
  background:#f5f7f8;
  color:#111820;
}
.player-nav-bar{
  max-width:1260px;
  margin:0 auto;
  padding:22px 5vw;
  display:flex;
  justify-content:space-between;
  gap:18px;
  font-weight:1000;
}
.player-nav-bar a{
  color:#005a7c;
}
.uf-player-hero{
  background:#ffffff;
  border-top:1px solid #dce5ea;
  border-bottom:1px solid #dce5ea;
  display:grid;
  grid-template-columns:minmax(320px, 520px) 1fr;
  max-width:1260px;
  margin:0 auto;
  box-shadow:0 14px 34px rgba(0,0,0,.06);
}
.player-image-panel{
  min-height:520px;
  background:
    linear-gradient(135deg,rgba(0,159,195,.12),rgba(17,24,32,.04)),
    #eef3f5;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  border-right:1px solid #dce5ea;
}
.profile-photo-large{
  width:300px;
  height:300px;
  border-radius:50%;
  background:
    radial-gradient(circle at top left,rgba(255,255,255,.75),transparent 32%),
    linear-gradient(135deg,#009fc3,#07090b);
  color:#ffffff;
  display:grid;
  place-items:center;
  font-size:92px;
  font-weight:1000;
  box-shadow:0 20px 50px rgba(0,0,0,.18);
}
.photo-note{
  color:#5d6b75;
  font-weight:800;
  margin-top:18px;
}
.player-hero-info{
  padding:58px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.sport-label{
  color:#009fc3;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-weight:1000;
}
.player-hero-info h1{
  color:#111820 !important;
  font-size:clamp(48px,7vw,96px) !important;
  letter-spacing:-.07em !important;
  line-height:.9;
  margin:8px 0 18px;
}
.number-position{
  display:flex;
  gap:18px;
  align-items:center;
  flex-wrap:wrap;
  color:#111820;
  font-weight:1000;
  font-size:26px;
}
.big-number{
  color:#009fc3;
  font-size:54px;
  letter-spacing:-.06em;
}
.social-row{
  display:flex;
  gap:12px;
  margin-top:28px;
}
.social-row a{
  border:1px solid #dce5ea;
  border-radius:999px;
  padding:12px 16px;
  color:#005a7c;
  font-weight:1000;
}
.player-content-grid{
  max-width:1260px;
  margin:28px auto 70px;
  padding:0 5vw;
  display:grid;
  grid-template-columns:340px minmax(0,1fr);
  gap:28px;
}
.bio-sidebar,
.bio-card{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:10px;
  box-shadow:0 8px 24px rgba(0,0,0,.05);
}
.bio-sidebar{
  padding:24px;
  align-self:start;
  position:sticky;
  top:120px;
}
.bio-sidebar h2{
  font-size:22px;
  border-bottom:4px solid #009fc3;
  padding-bottom:12px;
}
.bio-sidebar dl{
  display:grid;
  gap:14px;
}
.bio-sidebar dt{
  color:#5d6b75;
  font-size:12px;
  text-transform:uppercase;
  font-weight:1000;
  letter-spacing:.12em;
}
.bio-sidebar dd{
  margin:0;
  color:#111820;
  font-weight:900;
}
.tab-row{
  display:flex;
  gap:8px;
  margin-bottom:16px;
}
.tab-row a{
  padding:13px 20px;
  border:1px solid #dce5ea;
  background:#ffffff;
  color:#005a7c;
  font-weight:1000;
  border-radius:8px 8px 0 0;
}
.tab-row .active{
  background:#009fc3;
  color:#ffffff;
  border-color:#009fc3;
}
.bio-card{
  padding:28px;
  margin-bottom:20px;
}
.bio-card h2{
  font-size:32px;
  border-left:5px solid #009fc3;
  padding-left:16px;
}
.bio-card p{
  color:#4d5b65;
  line-height:1.65;
  font-size:17px;
}
.table-card.embedded{
  box-shadow:none !important;
}
.player-media-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.player-media-grid div{
  min-height:140px;
  background:linear-gradient(135deg,rgba(0,159,195,.72),rgba(7,9,11,.65));
  color:#fff;
  border-radius:10px;
  display:flex;
  align-items:flex-end;
  padding:18px;
  font-weight:1000;
}
@media(max-width:900px){
  .uf-player-hero,
  .player-content-grid{
    grid-template-columns:1fr;
  }
  .player-image-panel{
    min-height:360px;
    border-right:0;
    border-bottom:1px solid #dce5ea;
  }
  .profile-photo-large{
    width:220px;
    height:220px;
    font-size:64px;
  }
  .player-hero-info{
    padding:34px;
  }
  .bio-sidebar{
    position:static;
  }
}
@media(max-width:600px){
  .player-nav-bar{
    display:block;
  }
  .player-nav-bar div{
    margin-top:12px;
  }
  .player-media-grid{
    grid-template-columns:1fr;
  }
  .player-hero-info h1{
    font-size:42px !important;
  }
}


/* === ATL Marlins Website V3 roster + player page refinements === */
.roster-actions{
  display:flex;
  align-items:center;
  gap:14px;
  justify-content:flex-end;
  padding-right:22px;
}
.mini-social{
  width:28px;
  height:28px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#eef3f5;
  color:#005a7c;
  font-weight:1000;
}
.mini-social.muted{
  color:#a7b3ba;
}
.roster-row{
  grid-template-columns:minmax(420px,1fr) minmax(240px,.75fr) 180px !important;
}
.player-school-line{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  color:#5d6b75;
  font-weight:900;
  margin-top:12px;
}
.player-school-line span{
  padding-right:12px;
  border-right:1px solid #dce5ea;
}
.player-school-line span:last-child{
  border-right:0;
}
.bio-card h3{
  margin-top:24px;
  color:#111820 !important;
}
@media(max-width:1100px){
  .roster-row{
    grid-template-columns:1fr !important;
  }
  .roster-actions{
    justify-content:flex-start;
    padding-left:24px;
    padding-bottom:10px;
  }
}


/* === ATL Marlins Website V4 homepage: UF athletics style with teal/black/white === */
body{
  background:#f5f7f8 !important;
}
.site-logo{
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  padding:0 !important;
  width:86px !important;
  height:70px !important;
  object-fit:contain !important;
}
.footer-logo{
  background:transparent !important;
  padding:0 !important;
  border-radius:0 !important;
  width:82px !important;
  height:70px !important;
  object-fit:contain !important;
}
.mabl-inline{
  background:transparent !important;
  padding:0 !important;
  border-radius:0 !important;
  width:110px !important;
  max-height:48px !important;
}
.score-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  background:#ffffff;
  border-bottom:4px solid #009fc3;
  box-shadow:0 8px 18px rgba(0,0,0,.08);
}
.score-card.compact{
  min-height:92px;
  padding:18px 24px;
  border-right:1px solid #dce5ea;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.score-card.compact span{
  color:#009fc3;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-weight:1000;
}
.score-card.compact strong{
  color:#111820;
  font-size:19px;
}
.score-card.compact em{
  color:#5d6b75;
  font-style:normal;
  font-size:13px;
}
.uf-home-hero{
  position:relative;
  min-height:620px;
  display:grid;
  grid-template-columns:minmax(0,1.55fr) minmax(380px,.75fr);
  background:#07090b;
}
.hero-photo-panel{
  position:relative;
  min-height:620px;
  overflow:hidden;
}
.hero-photo-panel img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.hero-gradient{
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(7,9,11,.08),rgba(7,9,11,.12) 58%,rgba(7,9,11,.70));
}
.hero-badge{
  position:absolute;
  left:34px;
  bottom:34px;
  width:132px;
  height:112px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(10px);
  border-radius:18px;
  box-shadow:0 18px 44px rgba(0,0,0,.22);
}
.hero-badge img{
  width:112px;
  height:92px;
  object-fit:contain;
}
.hero-story-card{
  background:#ffffff;
  padding:52px 44px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  border-left:6px solid #009fc3;
}
.hero-story-card h1{
  color:#111820 !important;
  font-size:clamp(42px,5vw,76px) !important;
  letter-spacing:-.07em !important;
  line-height:.92;
}
.hero-story-card p{
  color:#5d6b75;
  line-height:1.55;
  font-size:18px;
}
.btn.teal{
  background:#009fc3;
  color:#ffffff;
}
.btn.dark{
  background:#07090b;
  color:#ffffff;
}
.btn.outline{
  background:#ffffff;
  color:#111820;
  border:1px solid #dce5ea;
}
.uf-home-main{
  padding:54px 5vw 72px;
  background:#f5f7f8;
}
.section-head.uf h2{
  color:#111820 !important;
  font-size:34px;
  letter-spacing:-.04em;
}
.schedule-rail.clean{
  grid-template-columns:repeat(4,1fr);
}
.game-card.light{
  background:#ffffff !important;
  color:#111820 !important;
  border:1px solid #dce5ea !important;
  border-top:4px solid #009fc3 !important;
  box-shadow:0 10px 26px rgba(0,0,0,.05) !important;
}
.home-two-col{
  display:grid;
  grid-template-columns:minmax(0,1.6fr) 360px;
  gap:24px;
  margin:56px 0;
}
.featured-story-card{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:10px;
  overflow:hidden;
  box-shadow:0 12px 30px rgba(0,0,0,.06);
  display:grid;
  grid-template-columns:.9fr 1fr;
}
.featured-story-card img{
  width:100%;
  height:100%;
  min-height:360px;
  object-fit:cover;
}
.featured-story-card div{
  padding:34px;
}
.featured-story-card h2{
  color:#111820 !important;
  font-size:42px;
  letter-spacing:-.05em;
}
.featured-story-card p{
  color:#5d6b75;
  line-height:1.55;
}
.featured-story-card a,
.home-news-card a{
  color:#005a7c;
  font-weight:1000;
}
.home-news-card{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:10px;
  padding:24px;
  box-shadow:0 12px 30px rgba(0,0,0,.06);
}
.home-news-card h2{
  color:#111820 !important;
  font-size:25px;
  border-bottom:4px solid #009fc3;
  padding-bottom:12px;
}
.home-news-card article{
  display:grid;
  grid-template-columns:38px 1fr;
  gap:10px;
  padding:15px 0;
  border-bottom:1px solid #dce5ea;
}
.home-news-card article span{
  width:38px;
  height:28px;
  border-radius:5px;
  background:#009fc3;
  color:#ffffff;
  display:grid;
  place-items:center;
  font-size:12px;
  font-weight:1000;
}
.home-news-card small{
  grid-column:2;
  color:#5d6b75;
}
.quick-link-row{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:14px;
  margin-bottom:56px;
}
.quick-link-row a{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:10px;
  min-height:118px;
  padding:22px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  box-shadow:0 8px 22px rgba(0,0,0,.05);
}
.quick-link-row strong{
  color:#111820;
  font-size:22px;
}
.quick-link-row span{
  color:#009fc3;
  font-weight:900;
}
.embed-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-bottom:56px;
}
.embed-card{
  background:#ffffff;
  border:2px dashed #b9c8d2;
  border-radius:12px;
  padding:28px;
  min-height:210px;
}
.embed-card h2{
  color:#111820 !important;
}
.embed-card p{
  color:#5d6b75;
}
.embed-card a,.embed-card span{
  color:#005a7c;
  font-weight:1000;
}
.home-gallery{
  display:grid;
  grid-template-columns:1.1fr 1fr 1fr;
  gap:18px;
}
.home-gallery article{
  position:relative;
  min-height:280px;
  border-radius:10px;
  overflow:hidden;
  box-shadow:0 12px 30px rgba(0,0,0,.10);
}
.home-gallery img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.home-gallery span{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  padding:20px;
  color:#fff;
  background:linear-gradient(0deg,rgba(0,0,0,.78),transparent);
  font-weight:1000;
  font-size:22px;
}
.league-sponsor-band{
  margin-top:58px;
  background:#ffffff;
  border-top:6px solid #009fc3;
  border-radius:10px;
  padding:34px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:32px;
  box-shadow:0 12px 30px rgba(0,0,0,.06);
}
.league-sponsor-band h2{
  color:#111820 !important;
}
.league-sponsor-band p{
  color:#5d6b75;
}
.league-sponsor-band img{
  max-width:260px;
  height:auto;
}
@media(max-width:1050px){
  .uf-home-hero,
  .home-two-col,
  .featured-story-card{
    grid-template-columns:1fr;
  }
  .hero-story-card{
    border-left:0;
    border-top:6px solid #009fc3;
  }
  .score-strip,.schedule-rail.clean,.quick-link-row,.embed-grid,.home-gallery{
    grid-template-columns:1fr 1fr;
  }
}
@media(max-width:650px){
  .score-strip,.schedule-rail.clean,.quick-link-row,.embed-grid,.home-gallery{
    grid-template-columns:1fr;
  }
  .hero-photo-panel{
    min-height:420px;
  }
  .uf-home-hero{
    min-height:auto;
  }
  .hero-story-card{
    padding:34px 24px;
  }
  .league-sponsor-band{
    flex-direction:column;
    align-items:flex-start;
  }
}


/* === ATL Marlins Website V5: functional roster controls === */
.roster-toolbar .tool-btn,
.roster-toolbar a.tool-btn{
  height:52px;
  min-width:58px;
  border-radius:9px;
  border:1px solid var(--line-light);
  background:#ffffff;
  color:var(--text);
  font-weight:1000;
  padding:0 16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.roster-toolbar .tool-btn:first-child,
.roster-toolbar a.tool-btn{
  background:var(--teal);
  color:#ffffff;
  border-color:var(--teal);
}
.roster-toolbar select{
  cursor:pointer;
  appearance:auto;
}
.roster-toolbar button{
  cursor:pointer;
}
.roster-helper{
  margin:-14px 0 20px;
  color:#5d6b75;
  font-size:14px;
}
.roster-actions{
  display:flex;
  align-items:center;
  gap:14px;
  justify-content:flex-end;
  padding-right:22px;
}
.roster-list.grid-view{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.roster-list.grid-view .roster-row{
  grid-template-columns:1fr !important;
  align-items:start;
  padding-bottom:18px;
}
.roster-list.grid-view .roster-main{
  display:block;
  text-align:center;
}
.roster-list.grid-view .headshot{
  margin:0 auto 14px;
  width:104px;
  height:104px;
  font-size:30px;
}
.roster-list.grid-view .player-meta{
  justify-content:center;
}
.roster-list.grid-view .roster-location,
.roster-list.grid-view .roster-actions{
  padding:0 22px 12px;
  text-align:center;
  justify-content:center;
}
@media(max-width:1000px){
  .roster-list.grid-view{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:650px){
  .roster-list.grid-view{
    grid-template-columns:1fr;
  }
}
@media print{
  .top-strip,.main-nav,.footer,.related-news,.roster-toolbar,.roster-helper{
    display:none !important;
  }
  body,.roster-page,.inner{
    background:#fff !important;
  }
  .roster-layout{
    display:block !important;
  }
  .roster-row{
    break-inside:avoid;
    box-shadow:none !important;
  }
}


/* === ATL Marlins Website V6 confirmed roster controls === */
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
.roster-toolbar .tool-btn,
.roster-toolbar a.tool-btn{
  text-decoration:none;
  height:52px;
  min-width:58px;
  border-radius:9px;
  border:1px solid var(--line-light);
  background:var(--teal);
  color:#ffffff;
  font-weight:1000;
  padding:0 16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.roster-toolbar button,
.roster-toolbar select{
  cursor:pointer;
}
.roster-toolbar select{
  background:#ffffff;
}
.roster-helper{
  margin:-10px 0 20px;
  color:#5d6b75;
  font-size:14px;
  font-weight:700;
}
.roster-actions{
  display:flex;
  align-items:center;
  gap:14px;
  justify-content:flex-end;
  padding-right:22px;
}
.roster-list.grid-view{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.roster-list.grid-view .roster-row{
  grid-template-columns:1fr !important;
  align-items:start;
  padding-bottom:18px;
}
.roster-list.grid-view .roster-main{
  display:block;
  text-align:center;
}
.roster-list.grid-view .headshot{
  margin:0 auto 14px;
  width:104px;
  height:104px;
  font-size:30px;
}
.roster-list.grid-view .player-meta{
  justify-content:center;
}
.roster-list.grid-view .roster-location,
.roster-list.grid-view .roster-actions{
  padding:0 22px 12px;
  text-align:center;
  justify-content:center;
}
@media(max-width:1000px){
  .roster-list.grid-view{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:650px){
  .roster-list.grid-view{
    grid-template-columns:1fr;
  }
}


/* === ATL Marlins Website V7: Google Form embed === */
.signup-page{
  background:#f5f7f8 !important;
}
.form-section{
  display:grid;
  grid-template-columns:340px minmax(0,1fr);
  gap:24px;
  align-items:start;
}
.form-copy{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:12px;
  padding:28px;
  box-shadow:0 10px 28px rgba(0,0,0,.06);
  position:sticky;
  top:120px;
}
.form-copy h2{
  color:#111820 !important;
  font-size:28px;
}
.form-copy p{
  color:#5d6b75;
  line-height:1.55;
}
.google-form-shell{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:12px;
  padding:10px;
  box-shadow:0 10px 28px rgba(0,0,0,.06);
  overflow:hidden;
}
.google-form-shell iframe{
  display:block;
  border-radius:8px;
  background:#ffffff;
}
@media(max-width:900px){
  .form-section{
    grid-template-columns:1fr;
  }
  .form-copy{
    position:static;
  }
}


/* === ATL Marlins Website V8: cleaner white footer/header logo treatment === */
.footer{
  background:#ffffff !important;
  color:#111820 !important;
  border-top:6px solid #009fc3 !important;
  box-shadow:0 -8px 24px rgba(0,0,0,.06);
}
.footer p{
  color:#5d6b75 !important;
}
.footer-brand strong{
  color:#111820 !important;
}
.footer-links a{
  color:#111820 !important;
}
.footer-links a:hover{
  color:#009fc3 !important;
}
.footer-logo{
  background:#ffffff !important;
  border:1px solid #dce5ea !important;
  border-radius:14px !important;
  padding:8px !important;
  width:86px !important;
  height:76px !important;
  object-fit:contain !important;
  filter:none !important;
  box-shadow:0 8px 22px rgba(0,0,0,.08);
}
.mabl-inline{
  background:#ffffff !important;
  border:1px solid #dce5ea !important;
  border-radius:8px !important;
  padding:4px 6px !important;
  width:112px !important;
  max-height:50px !important;
  object-fit:contain !important;
  filter:none !important;
  vertical-align:middle;
}
.main-nav{
  background:#ffffff !important;
}
.site-logo{
  background:#ffffff !important;
  border:1px solid #dce5ea !important;
  border-radius:12px !important;
  padding:6px !important;
  filter:none !important;
  box-shadow:0 6px 16px rgba(0,0,0,.06) !important;
}
.hero-badge{
  background:rgba(255,255,255,.96) !important;
}
.hero-badge img{
  filter:none !important;
}
.league-sponsor-band img{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:12px;
  padding:8px;
  box-shadow:0 8px 22px rgba(0,0,0,.06);
}
@media(max-width:700px){
  .footer{
    padding:28px 5vw !important;
  }
  .footer-brand{
    align-items:flex-start;
  }
}


/* === ATL Marlins Website V9: player photos and carousels === */
.photo-headshot{
  background-size:cover !important;
  background-position:center !important;
  color:transparent !important;
}
.photo-headshot::after{
  content:"";
  position:absolute;
  right:-3px;
  bottom:2px;
  width:22px;
  height:22px;
  border-radius:50%;
  background:var(--teal);
  border:3px solid #fff;
}
.player-carousel{
  width:100%;
  max-width:430px;
  margin:0 auto;
}
.carousel-stage{
  position:relative;
  width:100%;
  aspect-ratio:4 / 5;
  background:#dce5ea;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 22px 54px rgba(0,0,0,.18);
}
.carousel-slide{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:0;
  transition:opacity .25s ease;
}
.carousel-slide.active{
  opacity:1;
}
.carousel-control{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:42px;
  height:42px;
  border:0;
  border-radius:50%;
  background:rgba(255,255,255,.92);
  color:#111820;
  font-size:30px;
  font-weight:900;
  display:grid;
  place-items:center;
  cursor:pointer;
  box-shadow:0 8px 20px rgba(0,0,0,.18);
}
.carousel-control.prev{left:12px;}
.carousel-control.next{right:12px;}
.carousel-dots{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:14px;
  flex-wrap:wrap;
}
.carousel-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  border:0;
  background:#b9c8d2;
  cursor:pointer;
}
.carousel-dot.active{
  background:#009fc3;
  transform:scale(1.25);
}
.photo-gallery-grid{
  grid-template-columns:repeat(3,1fr);
}
.photo-gallery-grid img{
  width:100%;
  aspect-ratio:1 / 1;
  object-fit:cover;
  border-radius:10px;
  box-shadow:0 8px 22px rgba(0,0,0,.08);
}
@media(max-width:900px){
  .player-carousel{
    max-width:340px;
  }
}
@media(max-width:650px){
  .photo-gallery-grid{
    grid-template-columns:1fr 1fr;
  }
}


/* === ATL Marlins Website V13: Jimmy coaching photo === */
.coaching-photo-card img{
  width:100%;
  max-height:720px;
  object-fit:cover;
  object-position:center;
  border-radius:12px;
  box-shadow:0 14px 34px rgba(0,0,0,.12);
  margin-top:16px;
}


/* === ATL Marlins Website V14: UF-style stats page === */
.stats-page{
  background:#f5f7f8 !important;
}
.stats-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:28px;
  align-items:start;
}
.stats-title h1{
  font-size:42px !important;
  letter-spacing:-.04em !important;
  border-left:5px solid var(--teal);
  padding-left:18px;
}
.stats-toolbar{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  align-items:center;
  margin:24px 0;
}
.stats-toolbar select{
  height:52px;
  border:1px solid #dce5ea;
  background:#ffffff;
  color:#111820;
  border-radius:9px;
  padding:0 18px;
  font-weight:900;
  min-width:230px;
}
.stats-tabs,
.player-stats-tabs{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.stats-tabs button,
.player-stats-tabs button{
  height:52px;
  border:1px solid #dce5ea;
  background:#ffffff;
  color:#005a7c;
  border-radius:9px;
  padding:0 18px;
  font-weight:1000;
  cursor:pointer;
}
.stats-tabs button.active,
.player-stats-tabs button.active{
  background:#009fc3;
  border-color:#009fc3;
  color:#ffffff;
}
.stats-leader-grid{
  grid-template-columns:repeat(3,1fr) !important;
}
.stats-leader-grid article{
  min-height:145px;
}
.stats-leader-grid a{
  color:#005a7c;
}
.stats-leader-grid small{
  color:#5d6b75;
}
.stats-panel{
  display:none;
  margin-top:28px;
}
.stats-panel.active{
  display:block;
}
.stats-table-wrap{
  overflow:auto;
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:10px;
  box-shadow:0 8px 24px rgba(0,0,0,.05);
}
.stats-table{
  width:100%;
  border-collapse:collapse;
  min-width:1100px;
  background:#ffffff !important;
}
.stats-table th{
  position:sticky;
  top:0;
  z-index:1;
  background:#eef3f5 !important;
  color:#111820 !important;
  cursor:pointer;
}
.stats-table th:hover{
  color:#009fc3 !important;
}
.stats-table td a{
  color:#005a7c;
  font-weight:1000;
}
.stats-side-card{
  position:sticky;
  top:120px;
}
.player-stat-panel{
  display:none;
}
.player-stat-panel.active{
  display:block;
}
.player-stat-table{
  overflow:auto;
}
.player-stat-table table{
  min-width:820px;
}
.empty-state{
  background:#f5f7f8;
  border:1px dashed #b9c8d2;
  border-radius:10px;
  padding:18px;
  color:#5d6b75;
}
@media(max-width:1100px){
  .stats-layout{
    grid-template-columns:1fr;
  }
  .stats-side-card{
    position:static;
  }
  .stats-leader-grid{
    grid-template-columns:repeat(2,1fr) !important;
  }
}
@media(max-width:650px){
  .stats-leader-grid{
    grid-template-columns:1fr !important;
  }
  .stats-toolbar select{
    min-width:100%;
  }
}


/* === ATL Marlins Website V15: stats filtering + historical players === */
.historical-player-badge{
  display:inline-block;
  margin-left:8px;
  padding:3px 7px;
  border-radius:999px;
  background:#eef3f5;
  color:#5d6b75;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.stats-table tr[hidden]{
  display:none !important;
}
.stats-empty-message{
  margin-top:14px;
}


/* === ATL Marlins Website V16: corrected stats numbers and season lines === */
.stats-table td:first-child,
.stats-table th:first-child{
  white-space:nowrap;
}


/* === ATL Marlins Website V17: simplified season labels and player stat filters === */
.player-season-tabs{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:12px;
}
.player-season-tabs button{
  height:44px;
  border:1px solid #dce5ea;
  background:#ffffff;
  color:#005a7c;
  border-radius:9px;
  padding:0 14px;
  font-weight:1000;
  cursor:pointer;
}
.player-season-tabs button.active{
  background:#009fc3;
  border-color:#009fc3;
  color:#ffffff;
}
.player-stat-table tr[hidden],
.stats-table tr[hidden]{
  display:none !important;
}


/* === ATL Marlins Website V19: News archive and article pages === */
.news-archive-page{
  background:#f5f7f8 !important;
}
.archive-layout,
.article-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:28px;
  align-items:start;
}
.archive-title h1,
.article-header h1{
  font-size:clamp(42px,6vw,76px) !important;
  letter-spacing:-.06em !important;
  line-height:.95;
}
.archive-toolbar{
  margin:24px 0;
}
.archive-toolbar select{
  height:52px;
  min-width:220px;
  border:1px solid #dce5ea;
  border-radius:9px;
  background:#fff;
  color:#111820;
  font-weight:900;
  padding:0 16px;
}
.archive-list{
  display:grid;
  gap:18px;
}
.archive-article-card{
  display:grid;
  grid-template-columns:260px minmax(0,1fr);
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 10px 28px rgba(0,0,0,.06);
}
.archive-thumb{
  display:block;
  min-height:190px;
  background:#e8eef2;
}
.archive-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.archive-copy{
  padding:24px;
}
.archive-copy time,
.article-meta{
  color:#5d6b75;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:13px;
}
.archive-copy h2{
  font-size:28px;
  line-height:1.05;
  margin:8px 0 12px;
}
.archive-copy h2 a{
  color:#111820;
}
.archive-copy h2 a:hover,
.read-more:hover{
  color:#009fc3;
}
.archive-copy p{
  color:#5d6b75;
  line-height:1.55;
}
.read-more{
  color:#005a7c;
  font-weight:1000;
}
.archive-side,
.article-side{
  position:sticky;
  top:120px;
}
.article-page{
  background:#f5f7f8;
  padding:48px 5vw 72px;
}
.article-main{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:12px;
  box-shadow:0 12px 30px rgba(0,0,0,.06);
  overflow:hidden;
}
.article-main .back-link{
  display:inline-block;
  margin:26px 34px 0;
  color:#005a7c;
  font-weight:1000;
}
.article-header{
  padding:22px 34px 30px;
}
.article-meta{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}
.article-hero-image{
  width:100%;
  max-height:560px;
  object-fit:cover;
  display:block;
}
.article-body{
  padding:34px;
  max-width:920px;
}
.article-body p{
  color:#26333d;
  font-size:18px;
  line-height:1.75;
  margin:0 0 20px;
}
@media(max-width:1000px){
  .archive-layout,
  .article-layout{
    grid-template-columns:1fr;
  }
  .archive-side,
  .article-side{
    position:static;
  }
}
@media(max-width:700px){
  .archive-article-card{
    grid-template-columns:1fr;
  }
  .archive-thumb{
    min-height:220px;
  }
  .article-page{
    padding:28px 4vw 56px;
  }
  .article-header,
  .article-body{
    padding:24px;
  }
}


/* === ATL Marlins Website V20: natural logo blending === */
/* Remove the white boxes/cards around logos so transparent PNGs sit naturally on the page. */
.site-logo,
.footer-logo,
.mabl-inline,
.hero-badge,
.hero-badge img,
.league-sponsor-band img{
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  padding:0 !important;
  border-radius:0 !important;
  filter:none !important;
}

.site-logo{
  width:100px !important;
  height:86px !important;
  object-fit:contain !important;
}

.footer-logo{
  width:100px !important;
  height:88px !important;
  object-fit:contain !important;
}

.mabl-inline{
  width:120px !important;
  max-height:58px !important;
  object-fit:contain !important;
  vertical-align:middle;
  margin-right:10px;
}

.hero-badge{
  width:132px !important;
  height:112px !important;
  display:grid;
  place-items:center;
  backdrop-filter:none !important;
}

.hero-badge img{
  width:124px !important;
  height:104px !important;
  object-fit:contain !important;
}

.brand{
  gap:18px !important;
}

.footer-brand{
  gap:18px !important;
}

/* Footer MABL logo looked like a separate button/card; make it inline and natural. */
.footer p{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

/* On light backgrounds, a very subtle drop shadow helps the transparent logo read without a box. */
.site-logo,
.footer-logo,
.hero-badge img{
  filter:drop-shadow(0 4px 8px rgba(0,0,0,.10)) !important;
}

.mabl-inline,
.league-sponsor-band img{
  filter:drop-shadow(0 3px 6px rgba(0,0,0,.08)) !important;
}

/* Keep nav height balanced after increasing logo size. */
.main-nav{
  padding-top:14px !important;
  padding-bottom:14px !important;
}

@media(max-width:700px){
  .site-logo{
    width:82px !important;
    height:70px !important;
  }
  .footer-logo{
    width:82px !important;
    height:70px !important;
  }
  .mabl-inline{
    width:104px !important;
  }
}


/* === ATL Marlins Website V21: cleaned sponsorship page === */
.sponsors-page{
  background:#f5f7f8 !important;
}
.sponsor-hero-clean{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:28px;
  align-items:stretch;
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:16px;
  padding:38px;
  box-shadow:0 14px 34px rgba(0,0,0,.06);
  margin-bottom:28px;
}
.sponsor-hero-clean h1{
  color:#111820 !important;
  font-size:clamp(42px,6vw,76px) !important;
  line-height:.94;
  letter-spacing:-.06em;
  margin:8px 0 16px;
}
.sponsor-hero-clean p{
  color:#5d6b75;
  font-size:18px;
  line-height:1.6;
  max-width:900px;
}
.sponsor-hero-clean aside{
  background:linear-gradient(135deg,#f8fbfc,#e8f8fb);
  border:1px solid #dce5ea;
  border-radius:14px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:28px;
}
.sponsor-hero-clean aside img{
  width:150px;
  height:130px;
  object-fit:contain;
  margin-bottom:16px;
  filter:drop-shadow(0 4px 8px rgba(0,0,0,.10));
}
.sponsor-hero-clean aside strong{
  color:#111820;
  font-size:24px;
  line-height:1.1;
}
.sponsor-hero-clean aside span{
  color:#009fc3;
  font-weight:1000;
  margin-top:8px;
}
.sponsor-intro-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-bottom:38px;
}
.sponsor-intro-strip article{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-top:4px solid #009fc3;
  border-radius:12px;
  padding:22px;
  box-shadow:0 8px 24px rgba(0,0,0,.05);
}
.sponsor-intro-strip strong{
  display:block;
  color:#111820;
  font-size:20px;
  margin-bottom:8px;
}
.sponsor-intro-strip span{
  color:#5d6b75;
  line-height:1.45;
}
.sponsor-package-section{
  margin:42px 0;
}
.sponsor-offer-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.sponsor-offer-card{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:14px;
  padding:24px;
  box-shadow:0 10px 28px rgba(0,0,0,.06);
  display:flex;
  flex-direction:column;
  min-height:100%;
}
.sponsor-offer-card.premium{
  border-top:7px solid #009fc3;
  box-shadow:0 18px 44px rgba(0,159,195,.12);
}
.sponsor-offer-card.featured{
  border-top:7px solid #111820;
}
.offer-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  border-bottom:1px solid #dce5ea;
  padding-bottom:14px;
  margin-bottom:14px;
}
.offer-top h3{
  color:#111820 !important;
  font-size:26px;
  line-height:1.05;
  margin:0;
}
.offer-top strong{
  color:#009fc3;
  font-size:22px;
  white-space:nowrap;
}
.sponsor-offer-card p{
  color:#5d6b75;
  line-height:1.55;
  margin:0 0 14px;
}
.sponsor-offer-card ul{
  margin:0;
  padding-left:20px;
  color:#26333d;
  line-height:1.5;
}
.sponsor-offer-card li{
  margin:7px 0;
}
.custom-sponsor-cta{
  margin-top:48px;
  background:#111820;
  color:#ffffff;
  border-radius:16px;
  padding:34px;
  display:flex;
  justify-content:space-between;
  gap:28px;
  align-items:center;
  box-shadow:0 14px 34px rgba(0,0,0,.14);
}
.custom-sponsor-cta h2{
  color:#ffffff !important;
  font-size:42px;
  letter-spacing:-.05em;
}
.custom-sponsor-cta p{
  color:#d5dde2;
  line-height:1.6;
  max-width:900px;
}
.custom-sponsor-cta .btn.teal{
  flex:0 0 auto;
}
@media(max-width:1100px){
  .sponsor-offer-grid,
  .sponsor-intro-strip{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .sponsor-hero-clean{
    grid-template-columns:1fr;
  }
}
@media(max-width:700px){
  .sponsor-offer-grid,
  .sponsor-intro-strip{
    grid-template-columns:1fr;
  }
  .sponsor-hero-clean,
  .custom-sponsor-cta{
    padding:24px;
  }
  .custom-sponsor-cta{
    flex-direction:column;
    align-items:flex-start;
  }
  .offer-top{
    display:block;
  }
  .offer-top strong{
    display:block;
    margin-top:8px;
  }
}


/* === ATL Marlins Website V22: UF-style schedule page === */
.schedule-page-v22{
  background:#f5f7f8 !important;
}
.schedule-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:28px;
  align-items:start;
}
.schedule-title h1{
  font-size:clamp(42px,6vw,76px) !important;
  line-height:.94;
  letter-spacing:-.06em;
  border-left:5px solid #009fc3;
  padding-left:18px;
}
.schedule-toolbar{
  display:flex;
  gap:14px;
  align-items:center;
  flex-wrap:wrap;
  margin:24px 0;
}
.schedule-toolbar select{
  height:52px;
  min-width:220px;
  border:1px solid #dce5ea;
  border-radius:9px;
  background:#ffffff;
  color:#111820;
  font-weight:900;
  padding:0 16px;
}
.schedule-month-tabs{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.schedule-month-tabs button{
  height:52px;
  border:1px solid #dce5ea;
  background:#ffffff;
  color:#005a7c;
  border-radius:9px;
  padding:0 16px;
  font-weight:1000;
  cursor:pointer;
}
.schedule-month-tabs button.active{
  background:#009fc3;
  border-color:#009fc3;
  color:#ffffff;
}
.schedule-feature-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  background:#ffffff;
  border:1px solid #dce5ea;
  border-left:6px solid #009fc3;
  border-radius:12px;
  padding:26px;
  box-shadow:0 10px 28px rgba(0,0,0,.06);
  margin-bottom:34px;
}
.schedule-feature-card h2{
  color:#111820 !important;
  font-size:34px;
  margin:6px 0 8px;
}
.schedule-feature-card p{
  color:#5d6b75;
  line-height:1.55;
}
.schedule-source-section,
.schedule-results-section{
  margin:38px 0;
}
.schedule-source-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.schedule-source-card{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-top:4px solid #009fc3;
  border-radius:12px;
  padding:22px;
  box-shadow:0 8px 24px rgba(0,0,0,.05);
}
.schedule-source-card span{
  color:#009fc3;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:12px;
  font-weight:1000;
}
.schedule-source-card strong{
  display:block;
  color:#111820;
  font-size:22px;
  margin:8px 0;
}
.schedule-source-card p{
  color:#5d6b75;
}
.schedule-source-card a{
  color:#005a7c;
  font-weight:1000;
}
.schedule-empty-state{
  background:#ffffff;
  border:1px dashed #b9c8d2;
  border-radius:12px;
  padding:26px;
  box-shadow:0 8px 24px rgba(0,0,0,.04);
  margin-bottom:18px;
}
.schedule-empty-state h3{
  color:#111820 !important;
  font-size:28px;
  margin:0 0 10px;
}
.schedule-empty-state p{
  color:#5d6b75;
  line-height:1.6;
}
.schedule-import-format{
  background:#f5f7f8;
  border:1px solid #dce5ea;
  border-radius:10px;
  padding:16px;
  margin-top:16px;
}
.schedule-import-format pre{
  white-space:pre-wrap;
  margin:8px 0 0;
  color:#111820;
}
.schedule-table-card{
  overflow:auto;
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:12px;
  box-shadow:0 8px 24px rgba(0,0,0,.05);
}
.schedule-table{
  width:100%;
  border-collapse:collapse;
  min-width:900px;
}
.schedule-table th{
  background:#eef3f5 !important;
  color:#111820 !important;
}
.schedule-table td,
.schedule-table th{
  padding:14px;
  border-bottom:1px solid #dce5ea;
  text-align:left;
}
.schedule-side-card{
  position:sticky;
  top:120px;
}
@media(max-width:1100px){
  .schedule-layout{
    grid-template-columns:1fr;
  }
  .schedule-side-card{
    position:static;
  }
  .schedule-source-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:700px){
  .schedule-feature-card{
    flex-direction:column;
    align-items:flex-start;
  }
  .schedule-source-grid{
    grid-template-columns:1fr;
  }
  .schedule-toolbar select{
    min-width:100%;
  }
}


/* === ATL Marlins Website V23: official-source schedule page === */
.schedule-page-v23{
  background:#f5f7f8 !important;
}
.official-scoreboard-card{
  border-left:6px solid #111820 !important;
}
.official-scoreboard-card img{
  width:140px;
  height:120px;
  object-fit:contain;
  filter:drop-shadow(0 4px 8px rgba(0,0,0,.10));
}
.schedule-summary-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin:0 0 36px;
}
.schedule-summary-grid article{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-top:4px solid #009fc3;
  border-radius:12px;
  padding:22px;
  box-shadow:0 8px 24px rgba(0,0,0,.05);
}
.schedule-summary-grid span{
  color:#009fc3;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:12px;
  font-weight:1000;
}
.schedule-summary-grid strong{
  display:block;
  color:#111820;
  font-size:28px;
  margin:7px 0;
  letter-spacing:-.04em;
}
.schedule-summary-grid p{
  color:#5d6b75;
  margin:0;
}
.official-schedule-table th:nth-child(5),
.official-schedule-table th:nth-child(6){
  text-align:center;
}
.official-schedule-table td:nth-child(5),
.official-schedule-table td:nth-child(6){
  text-align:center;
  font-weight:1000;
}
@media(max-width:1000px){
  .schedule-summary-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:650px){
  .schedule-summary-grid{
    grid-template-columns:1fr;
  }
  .official-scoreboard-card img{
    width:110px;
    height:95px;
  }
}


/* === ATL Marlins Website V24: official schedule results === */
.official-game-list-section{
  margin:38px 0;
}
.official-game-list{
  display:grid;
  gap:14px;
}
.official-game-card{
  display:grid;
  grid-template-columns:86px minmax(0,1fr) 120px;
  gap:18px;
  align-items:center;
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:12px;
  box-shadow:0 8px 24px rgba(0,0,0,.05);
  overflow:hidden;
}
.official-game-card.win{
  border-left:6px solid #009fc3;
}
.official-game-card.loss{
  border-left:6px solid #111820;
}
.official-game-card.tbd{
  border-left:6px solid #b9c8d2;
}
.game-date-box{
  min-height:112px;
  background:#eef3f5;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  color:#111820;
}
.game-date-box span,
.game-date-box em{
  font-size:12px;
  font-weight:1000;
  text-transform:uppercase;
  color:#5d6b75;
  font-style:normal;
}
.game-date-box strong{
  font-size:34px;
  line-height:1;
}
.game-info h3{
  color:#111820 !important;
  font-size:24px;
  margin:0 0 4px;
}
.game-info p{
  margin:0 0 4px;
  color:#5d6b75;
}
.game-info small{
  color:#5d6b75;
  line-height:1.35;
}
.game-result-box{
  padding:18px;
  text-align:center;
}
.game-result-box span{
  display:inline-grid;
  place-items:center;
  width:36px;
  height:36px;
  border-radius:50%;
  background:#eef3f5;
  color:#111820;
  font-weight:1000;
  margin-bottom:8px;
}
.official-game-card.win .game-result-box span{
  background:#009fc3;
  color:#ffffff;
}
.official-game-card.loss .game-result-box span{
  background:#111820;
  color:#ffffff;
}
.game-result-box strong{
  display:block;
  color:#111820;
  font-size:24px;
}
.result-pill{
  display:inline-flex;
  justify-content:center;
  min-width:34px;
  padding:5px 8px;
  border-radius:999px;
  font-weight:1000;
  background:#eef3f5;
  color:#111820;
}
.result-pill.win{
  background:#009fc3;
  color:#ffffff;
}
.result-pill.loss{
  background:#111820;
  color:#ffffff;
}
.result-pill.tbd{
  background:#eef3f5;
  color:#5d6b75;
}
.schedule-discrepancy-card{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-left:6px solid #111820;
  border-radius:12px;
  padding:26px;
  box-shadow:0 8px 24px rgba(0,0,0,.05);
  margin:34px 0 0;
}
.schedule-discrepancy-card h2{
  color:#111820 !important;
  font-size:32px;
  letter-spacing:-.04em;
}
.schedule-discrepancy-card p,
.schedule-discrepancy-card li{
  color:#5d6b75;
  line-height:1.55;
}
.schedule-discrepancy-card li{
  margin:8px 0;
}
@media(max-width:750px){
  .official-game-card{
    grid-template-columns:70px 1fr;
  }
  .game-result-box{
    grid-column:1 / -1;
    border-top:1px solid #dce5ea;
  }
}


/* === ATL Marlins Website V26: Fall schedule support === */
.official-game-card.tie{
  border-left:6px solid #77838c;
}
.official-game-card.tie .game-result-box span,
.result-pill.tie{
  background:#77838c;
  color:#ffffff;
}


/* === ATL Marlins Website V28: game buttons and individual game pages === */
.official-game-card{
  grid-template-columns:86px minmax(0,1fr) 120px 310px !important;
}
.game-card-actions{
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
  padding:18px;
}
.game-card-actions a,
.game-btn{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  min-height:42px;
  border-radius:9px;
  background:#0b2d83;
  color:#ffffff !important;
  font-weight:1000;
  text-decoration:none;
  padding:0 16px;
}
.game-card-actions a:nth-child(2),
.game-btn.outline{
  background:#111820;
  outline:3px solid #009fc3;
  outline-offset:-3px;
}
.game-card-actions a:nth-child(3),
.game-btn.dark{
  background:#005a7c;
}
.table-action-link{
  color:#005a7c;
  font-weight:1000;
}
.game-recap-page{
  background:#f5f7f8;
  padding:48px 5vw 72px;
}
.game-article-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:28px;
  align-items:start;
}
.game-article-main{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:14px;
  box-shadow:0 12px 30px rgba(0,0,0,.06);
  overflow:hidden;
}
.game-article-main .back-link{
  display:inline-block;
  margin:26px 34px 0;
  color:#005a7c;
  font-weight:1000;
}
.game-story-header{
  padding:22px 34px 30px;
}
.game-story-header h1{
  color:#111820 !important;
  font-size:clamp(40px,6vw,72px);
  line-height:.95;
  letter-spacing:-.06em;
}
.game-score-hero{
  display:grid;
  grid-template-columns:1fr 220px 1fr;
  align-items:center;
  gap:20px;
  padding:34px;
  background:linear-gradient(135deg,#f8fbfc,#e8f8fb);
  border-top:1px solid #dce5ea;
  border-bottom:1px solid #dce5ea;
}
.team-side{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:8px;
}
.team-side img{
  width:110px;
  height:100px;
  object-fit:contain;
}
.team-side strong{
  color:#111820;
  font-size:24px;
}
.team-side span{
  color:#111820;
  font-size:58px;
  font-weight:1000;
  line-height:1;
}
.opponent-mark{
  width:92px;
  height:92px;
  border-radius:50%;
  background:#111820;
  color:#ffffff;
  display:grid;
  place-items:center;
  font-size:30px;
  font-weight:1000;
}
.score-center{
  text-align:center;
}
.score-center span{
  display:inline-grid;
  place-items:center;
  width:46px;
  height:46px;
  border-radius:50%;
  background:#009fc3;
  color:#ffffff;
  font-weight:1000;
  margin-bottom:10px;
}
.score-center strong{
  display:block;
  color:#111820;
  font-size:42px;
}
.score-center em{
  color:#5d6b75;
  font-style:normal;
  font-weight:900;
}
.game-action-row{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  padding:26px 34px 0;
}
.game-content-card{
  margin:26px 34px;
  padding:26px;
  border:1px solid #dce5ea;
  border-radius:12px;
  background:#ffffff;
  box-shadow:0 8px 24px rgba(0,0,0,.04);
}
.game-content-card h2{
  color:#111820 !important;
  font-size:34px;
  letter-spacing:-.04em;
}
.game-content-card p{
  color:#5d6b75;
  line-height:1.6;
}
.mini-box-score{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.mini-box-score div{
  background:#f5f7f8;
  border:1px solid #dce5ea;
  border-radius:10px;
  padding:16px;
}
.mini-box-score strong{
  display:block;
  color:#009fc3;
  text-transform:uppercase;
  font-size:12px;
  letter-spacing:.1em;
}
.mini-box-score span{
  display:block;
  color:#111820;
  font-weight:1000;
  margin-top:6px;
}
.disabled-link{
  pointer-events:none;
  opacity:.7;
}
@media(max-width:1200px){
  .official-game-card{
    grid-template-columns:86px minmax(0,1fr) 120px !important;
  }
  .game-card-actions{
    grid-column:1 / -1;
    grid-template-columns:repeat(3,1fr);
    border-top:1px solid #dce5ea;
  }
}
@media(max-width:900px){
  .game-article-layout,
  .game-score-hero{
    grid-template-columns:1fr;
  }
}
@media(max-width:650px){
  .official-game-card{
    grid-template-columns:70px 1fr !important;
  }
  .game-card-actions{
    grid-template-columns:1fr;
  }
  .mini-box-score{
    grid-template-columns:1fr;
  }
}


/* === ATL Marlins Website V29: jersey number bubble on roster headshots === */
.roster-row .headshot{
  position:relative !important;
  overflow:visible !important;
}
.roster-row .headshot.photo-placeholder{
  display:grid;
  place-items:center;
}
.roster-row .headshot.photo-headshot::after{
  display:none !important;
}
.jersey-bubble{
  position:absolute;
  right:-6px;
  bottom:-6px;
  min-width:30px;
  height:30px;
  padding:0 7px;
  border-radius:999px;
  background:#009fc3;
  color:#ffffff;
  border:3px solid #ffffff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  font-weight:1000;
  line-height:1;
  box-shadow:0 6px 14px rgba(0,0,0,.18);
  z-index:2;
}
.roster-list.grid-view .jersey-bubble{
  right:2px;
  bottom:2px;
  min-width:34px;
  height:34px;
  font-size:13px;
}


/* === ATL Marlins Website V30: populated summer game recaps and box scores === */
.game-story-body p{
  color:#26333d !important;
  font-size:18px;
  line-height:1.78 !important;
  margin:0 0 20px;
}
.box-score-image{
  width:100%;
  max-width:720px;
  display:block;
  margin:12px auto 24px;
  border-radius:10px;
  box-shadow:0 10px 28px rgba(0,0,0,.16);
  background:#111820;
}
.game-content-card .mini-box-score{margin-top:18px;}


/* === ATL Marlins Website V31: custom box scores and Instagram icons === */
.custom-box-score-card{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 8px 24px rgba(0,0,0,.06);
  margin:14px 0 24px;
}
.box-score-topline{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:center;
  background:#111820;
  color:#ffffff;
  padding:14px 18px;
}
.box-score-topline span{
  color:#009fc3;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:12px;
  font-weight:1000;
}
.box-score-topline strong{
  font-size:17px;
}
.line-score-scroll{
  overflow:auto;
}
.line-score-table{
  width:100%;
  min-width:720px;
  border-collapse:collapse;
  background:#ffffff;
}
.line-score-table th,
.line-score-table td{
  padding:13px 12px;
  border-bottom:1px solid #dce5ea;
  text-align:center;
  color:#111820;
}
.line-score-table thead th{
  background:#eef3f5;
  color:#5d6b75;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.line-score-table tbody th{
  text-align:left;
  min-width:190px;
}
.line-score-table .team-abbr{
  display:inline-block;
  min-width:48px;
  color:#005a7c;
  font-weight:1000;
  margin-right:10px;
}
.line-score-table .team-full{
  color:#111820;
  font-weight:900;
}
.line-score-table .winner .team-abbr::before{
  content:"▶";
  color:#009fc3;
  margin-right:6px;
  font-size:11px;
}
.line-score-table .total-runs{
  background:#e8f8fb;
  color:#005a7c;
  font-weight:1000;
  font-size:18px;
}
.instagram-icon{
  width:18px;
  height:18px;
  display:block;
}
.instagram-icon rect,
.instagram-icon circle{
  fill:none;
  stroke:currentColor;
  stroke-width:2;
}
.social-row a:has(.instagram-icon),
.mini-social{
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
}
.social-row a:has(.instagram-icon){
  width:44px;
  height:44px;
  border-radius:999px;
  padding:0 !important;
}
.social-row a:has(.instagram-icon) .instagram-icon{
  width:21px;
  height:21px;
}
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}


/* === ATL Marlins Website V32: Fall and Santa Shuffle recap polish === */
.game-story-body p{
  color:#26333d !important;
  font-size:18px;
  line-height:1.78 !important;
  margin:0 0 20px;
}
.game-story-header .article-meta span{
  display:inline-flex;
  align-items:center;
}


/* === ATL Marlins Website V34: GameChanger embedded schedule widget === */
.gamechanger-widget-section{
  margin:34px 0;
}
.gamechanger-widget-card{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:14px;
  padding:18px;
  box-shadow:0 10px 28px rgba(0,0,0,.06);
  overflow:hidden;
}
#gc-schedule-widget-mjg9{
  width:100%;
  min-height:220px;
}


/* === ATL Marlins Website V35: season-specific months === */
.schedule-month-tabs button[hidden],
[data-schedule-game][hidden]{
  display:none !important;
}


/* === ATL Marlins Website V36: homepage live embeds === */
.home-live-embed{
  background:#ffffff !important;
  border:1px solid #dce5ea !important;
  border-radius:14px !important;
  padding:24px !important;
  box-shadow:0 10px 28px rgba(0,0,0,.06);
  overflow:hidden;
}
.home-live-embed h3{
  margin-bottom:8px;
}
.home-live-embed p{
  color:#5d6b75;
  margin-bottom:14px;
}
.embed-widget-wrap{
  background:#f5f7f8;
  border:1px solid #dce5ea;
  border-radius:12px;
  padding:12px;
  min-height:230px;
}
#gc-schedule-widget-home{
  width:100%;
  min-height:230px;
}
.social-embed-actions{
  margin-bottom:12px;
}
.social-embed-actions a{
  color:#005a7c;
  font-weight:1000;
}
.instagram-profile-embed{
  width:100%;
  min-height:410px;
  border:0;
  border-radius:12px;
  background:#f5f7f8;
}
.tiktok-home-embed .tiktok-embed{
  margin:0 auto !important;
  width:100%;
  border-radius:12px;
}
@media(max-width:900px){
  .instagram-profile-embed{
    min-height:360px;
  }
}


/* === ATL Marlins Website V37: official TikTok creator embed === */
.tiktok-home-embed .tiktok-embed{
  margin:0 auto !important;
  width:100% !important;
}


/* === ATL Marlins Website V38: official Instagram profile embed === */
.instagram-home-embed .instagram-media{
  margin-left:auto !important;
  margin-right:auto !important;
}


/* === ATL Marlins Website V39: homepage embeds fixed === */
.embed-grid .home-live-embed{
  background:#ffffff !important;
  border:1px solid #dce5ea !important;
  border-radius:14px !important;
  border-style:solid !important;
  padding:24px !important;
  box-shadow:0 10px 28px rgba(0,0,0,.06) !important;
  overflow:hidden;
}
.embed-grid .home-live-embed h2{
  margin-bottom:8px;
}
.embed-grid .home-live-embed p{
  color:#5d6b75;
  margin-bottom:14px;
}
.embed-widget-wrap{
  background:#f5f7f8;
  border:1px solid #dce5ea;
  border-radius:12px;
  padding:12px;
  min-height:230px;
}
#gc-schedule-widget-home{
  width:100%;
  min-height:230px;
}
.social-embed-actions{
  margin-bottom:12px;
}
.social-embed-actions a{
  color:#005a7c;
  font-weight:1000;
}
.instagram-home-embed .instagram-media,
.tiktok-home-embed .tiktok-embed{
  margin-left:auto !important;
  margin-right:auto !important;
}
.tiktok-home-embed .tiktok-embed{
  width:100% !important;
}


/* === ATL Marlins Website V40: cleaner stacked live-feed section === */
.social-feed-section{
  padding:56px 5vw;
  background:#f5f7f8;
}
.social-feed-layout{
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(320px,.72fr);
  gap:22px;
  align-items:start;
}
.feed-main-stack{
  display:grid;
  gap:22px;
}
.feed-side-panel{
  display:grid;
  gap:22px;
  position:sticky;
  top:120px;
}
.feed-card{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:16px;
  box-shadow:0 12px 30px rgba(0,0,0,.06);
  overflow:hidden;
  padding:24px;
}
.feed-card-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:18px;
  border-bottom:1px solid #dce5ea;
  padding-bottom:16px;
  margin-bottom:14px;
}
.feed-card-header h3{
  color:#111820 !important;
  font-size:clamp(30px,4vw,46px);
  line-height:.96;
  letter-spacing:-.06em;
  margin:4px 0 0;
}
.feed-card-header.compact h3{
  font-size:34px;
}
.feed-card-header a{
  color:#005a7c;
  font-weight:1000;
  white-space:nowrap;
  margin-top:8px;
}
.feed-copy{
  color:#5d6b75;
  line-height:1.5;
  margin:0 0 16px;
}
.social-feed-section .embed-widget-wrap,
.social-embed-shell{
  background:#f5f7f8;
  border:1px solid #dce5ea;
  border-radius:14px;
  padding:14px;
  overflow:hidden;
}
#gc-schedule-widget-home{
  width:100%;
  min-height:240px;
}
.instagram-shell{
  display:flex;
  justify-content:center;
  min-height:320px;
}
.tiktok-shell{
  display:flex;
  justify-content:center;
}
.instagram-home-embed .instagram-media,
.tiktok-home-embed .tiktok-embed{
  margin-left:auto !important;
  margin-right:auto !important;
}
.feed-cta-card{
  background:linear-gradient(135deg,#111820,#053445);
  color:#ffffff;
  border-radius:16px;
  padding:28px;
  box-shadow:0 14px 34px rgba(0,0,0,.16);
}
.feed-cta-card img{
  width:116px;
  height:96px;
  object-fit:contain;
  filter:drop-shadow(0 6px 12px rgba(0,0,0,.28));
  margin-bottom:14px;
}
.feed-cta-card h3{
  color:#ffffff !important;
  font-size:34px;
  line-height:1;
  letter-spacing:-.05em;
  margin:0 0 10px;
}
.feed-cta-card p{
  color:#d5dde2;
  line-height:1.55;
  margin-bottom:18px;
}
@media(max-width:1100px){
  .social-feed-layout{
    grid-template-columns:1fr;
  }
  .feed-side-panel{
    position:static;
    grid-template-columns:1fr;
  }
}
@media(max-width:700px){
  .social-feed-section{
    padding:38px 4vw;
  }
  .feed-card{
    padding:18px;
  }
  .feed-card-header{
    flex-direction:column;
  }
  .feed-card-header a{
    margin-top:0;
  }
  .feed-card-header h3{
    font-size:34px;
  }
}


/* === ATL Marlins Website V41: cleaned media page with Lightroom embeds === */
.media-page-v41{
  background:#f5f7f8 !important;
}
.media-hero-clean{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:28px;
  align-items:stretch;
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:16px;
  padding:38px;
  box-shadow:0 14px 34px rgba(0,0,0,.06);
  margin-bottom:28px;
}
.media-hero-clean h1{
  color:#111820 !important;
  font-size:clamp(42px,6vw,76px) !important;
  line-height:.94;
  letter-spacing:-.06em;
  margin:8px 0 16px;
}
.media-hero-clean p{
  color:#5d6b75;
  font-size:18px;
  line-height:1.6;
  max-width:900px;
}
.media-hero-clean aside{
  background:linear-gradient(135deg,#f8fbfc,#e8f8fb);
  border:1px solid #dce5ea;
  border-radius:14px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:28px;
}
.media-hero-clean aside img{
  width:150px;
  height:130px;
  object-fit:contain;
  margin-bottom:16px;
  filter:drop-shadow(0 4px 8px rgba(0,0,0,.10));
}
.media-hero-clean aside strong{
  color:#111820;
  font-size:24px;
  line-height:1.1;
}
.media-hero-clean aside span{
  color:#009fc3;
  font-weight:1000;
  margin-top:8px;
}
.media-feature-strip{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-bottom:38px;
}
.media-feature-strip article{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-top:4px solid #009fc3;
  border-radius:12px;
  padding:22px;
  box-shadow:0 8px 24px rgba(0,0,0,.05);
}
.media-feature-strip strong{
  display:block;
  color:#111820;
  font-size:20px;
  margin-bottom:8px;
}
.media-feature-strip span{
  color:#5d6b75;
  line-height:1.45;
}
.media-album-list{
  display:grid;
  gap:28px;
}
.media-album-card{
  background:#ffffff;
  border:1px solid #dce5ea;
  border-radius:16px;
  box-shadow:0 14px 34px rgba(0,0,0,.07);
  overflow:hidden;
}
.media-album-copy{
  padding:26px 28px;
  display:flex;
  gap:16px;
  align-items:flex-start;
  justify-content:space-between;
  flex-wrap:wrap;
  border-bottom:1px solid #dce5ea;
}
.media-album-copy h2{
  color:#111820 !important;
  font-size:clamp(30px,4vw,46px);
  line-height:.96;
  letter-spacing:-.05em;
  margin:4px 0 8px;
}
.media-album-copy p:not(.kicker){
  color:#5d6b75;
  line-height:1.5;
  max-width:700px;
}
.media-album-copy a{
  color:#005a7c;
  font-weight:1000;
  white-space:nowrap;
}
.lightroom-embed-wrap{
  position:relative;
  padding-bottom:56.25%;
  height:0;
  overflow:hidden;
  background:#2d2d2d;
}
.lightroom-embed-wrap iframe{
  width:100%;
  height:100%;
  position:absolute;
  top:0;
  left:0;
  border:0;
}
@media(max-width:1000px){
  .media-hero-clean{
    grid-template-columns:1fr;
  }
}
@media(max-width:800px){
  .media-feature-strip{
    grid-template-columns:1fr;
  }
  .media-hero-clean{
    padding:24px;
  }
  .media-album-copy{
    display:block;
  }
  .media-album-copy a{
    display:inline-block;
    margin-top:12px;
  }
}


/* === ATL Marlins Website V42: linked season Lightroom albums on game pages === */
.game-lightroom-embed{
  margin:16px 0 18px;
  border-radius:12px;
  box-shadow:0 10px 28px rgba(0,0,0,.12);
}
.game-content-card .lightroom-embed-wrap + .btn{
  margin-top:4px;
}


/* === ATL Marlins Website V43: official footer icons and legal bar === */
.footer-icon-links{
  display:flex !important;
  align-items:center;
  gap:12px !important;
  flex-wrap:wrap;
}
.footer-icon-links a,
.official-social-icons a{
  width:44px;
  height:44px;
  border-radius:999px;
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  background:#009fc3;
  color:#ffffff !important;
  text-decoration:none;
  transition:transform .15s ease, background .15s ease;
}
.footer-icon-links a:hover,
.official-social-icons a:hover{
  transform:translateY(-2px);
  background:#005a7c;
}
.footer-icon-links span{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
.footer-social-icon{
  width:21px;
  height:21px;
  display:block;
}
.footer-social-icon path,
.footer-social-icon rect,
.footer-social-icon circle{
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.footer-social-icon.gc-icon{
  width:24px;
  height:24px;
}
.official-footer-bar{
  background:#12358f;
  color:#ffffff;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  padding:28px 12vw;
}
.official-footer-bar strong{
  display:block;
  font-size:18px;
  line-height:1.35;
}
.official-footer-bar nav{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:6px;
}
.official-footer-bar nav a{
  color:#ffffff;
  font-weight:1000;
  text-decoration:underline;
  text-underline-offset:3px;
}
.official-footer-bar nav a + a::before{
  content:"|";
  color:rgba(255,255,255,.65);
  margin-right:8px;
  text-decoration:none;
}
.official-social-icons{
  display:flex;
  gap:12px;
  align-items:center;
  flex:0 0 auto;
}
.official-social-icons a{
  background:#ff4b1f;
}
.legal-footer-bar{
  background:#ffffff;
  color:#26333d;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  padding:24px 12vw;
  border-top:1px solid #dce5ea;
}
.legal-footer-bar nav{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
}
.legal-footer-bar nav a{
  color:#26333d;
  text-decoration:none;
}
.legal-footer-bar nav a:hover{
  color:#005a7c;
}
.legal-footer-bar span{
  color:#5d6b75;
  text-align:right;
}
@media(max-width:900px){
  .official-footer-bar,
  .legal-footer-bar{
    padding:24px 6vw;
    flex-direction:column;
    align-items:flex-start;
  }
  .legal-footer-bar span{
    text-align:left;
  }
}


/* === ATL Marlins Website V44: cleaned footer, no duplicate info === */
.official-footer-bar,
.legal-footer-bar{
  display:none !important;
}
.footer{
  border-top:5px solid #009fc3;
  padding:30px 5vw !important;
  min-height:auto !important;
}
.footer-brand{
  gap:16px;
}
.footer-brand p{
  margin-top:4px;
}
.footer-icon-links{
  gap:10px !important;
}
.footer-icon-links a{
  width:42px !important;
  height:42px !important;
  background:#009fc3 !important;
}
.official-footer-clean{
  background:#12358f;
  color:#ffffff;
  padding:18px 5vw;
}
.official-footer-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  max-width:1440px;
  margin:0 auto;
}
.official-footer-clean p{
  margin:0;
  font-weight:900;
  line-height:1.35;
}
.official-footer-clean nav{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}
.official-footer-clean nav a{
  color:#ffffff;
  font-weight:900;
  text-decoration:underline;
  text-underline-offset:3px;
}
@media(max-width:800px){
  .official-footer-inner{
    flex-direction:column;
    align-items:flex-start;
  }
}


/* === ATL Marlins Website V45: cleaned homepage gallery/CTA sections === */
.feed-cta-card{
  display:none !important;
}
.home-gallery-links{
  padding:46px 5vw 64px;
  background:#f5f7f8;
}
.home-gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
.home-gallery-card{
  display:flex;
  min-height:190px;
  flex-direction:column;
  justify-content:space-between;
  background:#ffffff;
  border:1px solid #dce5ea;
  border-top:5px solid #009fc3;
  border-radius:16px;
  padding:24px;
  box-shadow:0 12px 30px rgba(0,0,0,.06);
  text-decoration:none;
  transition:transform .15s ease, box-shadow .15s ease;
}
.home-gallery-card:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 36px rgba(0,0,0,.10);
}
.home-gallery-card span{
  color:#009fc3;
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:12px;
}
.home-gallery-card strong{
  color:#111820;
  font-size:clamp(24px,2.7vw,34px);
  line-height:1;
  letter-spacing:-.05em;
  margin:18px 0;
}
.home-gallery-card em{
  color:#005a7c;
  font-style:normal;
  font-weight:1000;
}
.home-gallery-card.featured{
  background:linear-gradient(135deg,#111820,#063545);
  border-color:#063545;
  border-top-color:#009fc3;
}
.home-gallery-card.featured strong,
.home-gallery-card.featured em{
  color:#ffffff;
}
.home-gallery-card.featured span{
  color:#5ed7ee;
}
@media(max-width:1050px){
  .home-gallery-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:650px){
  .home-gallery-grid{
    grid-template-columns:1fr;
  }
  .home-gallery-links{
    padding:34px 4vw 46px;
  }
}


/* === ATL Marlins Website V46: media cleanup + cleaner GameChanger footer icon === */
.media-feature-strip{
  display:none !important;
}
.gc-badge text{
  fill:currentColor;
  stroke:none !important;
  font-family:Arial, Helvetica, sans-serif;
  font-size:17px;
  font-weight:900;
  letter-spacing:-1px;
}
.gc-badge path,
.gc-badge rect,
.gc-badge circle{
  display:none !important;
}


/* === ATL Marlins Website V47: provided GameChanger icon asset === */
.footer-social-img{
  display:block;
  width:24px;
  height:24px;
  object-fit:cover;
}
.gc-footer-img{
  width:26px;
  height:26px;
  border-radius:7px;
}
.footer-icon-links a:has(.gc-footer-img),
.official-social-icons a:has(.gc-footer-img){
  background:#06152f !important;
  overflow:hidden;
}
.footer-icon-links a:has(.gc-footer-img):hover,
.official-social-icons a:has(.gc-footer-img):hover{
  background:#06152f !important;
}


/* === ATL Marlins Website V48: mobile responsiveness overhaul === */

/* Global mobile safety */
*,
*::before,
*::after{
  box-sizing:border-box;
}
html,
body{
  max-width:100%;
  overflow-x:hidden;
}
img,
iframe,
video,
table{
  max-width:100%;
}
.page,
.inner{
  width:100%;
}
section{
  max-width:100%;
}

/* Navigation */
.nav-toggle{
  display:none;
}
@media(max-width:900px){
  .top-strip{
    display:none !important;
  }
  .main-nav{
    position:sticky;
    top:0;
    z-index:1000;
    padding:12px 4vw !important;
    gap:12px;
    align-items:center;
  }
  .main-nav .brand{
    min-width:0;
    max-width:calc(100% - 58px);
  }
  .main-nav .brand img,
  .main-nav .site-logo{
    width:54px !important;
    height:54px !important;
    object-fit:contain;
    flex:0 0 auto;
  }
  .main-nav .brand strong{
    font-size:16px !important;
    line-height:1.05;
    white-space:normal;
  }
  .main-nav .brand span{
    font-size:10px !important;
    line-height:1.1;
  }
  .nav-toggle{
    display:inline-flex !important;
    align-items:center;
    justify-content:center;
    width:44px;
    height:44px;
    border:1px solid #dce5ea;
    border-radius:10px;
    background:#ffffff;
    color:#111820;
    font-size:22px;
    font-weight:900;
    cursor:pointer;
    margin-left:auto;
  }
  .nav-links{
    display:none !important;
    position:absolute;
    left:4vw;
    right:4vw;
    top:76px;
    background:#ffffff;
    border:1px solid #dce5ea;
    border-radius:14px;
    box-shadow:0 18px 42px rgba(0,0,0,.18);
    padding:12px;
    grid-template-columns:1fr;
    gap:4px;
  }
  .main-nav.nav-open .nav-links{
    display:grid !important;
  }
  .nav-links a{
    display:block;
    padding:14px 12px;
    border-radius:10px;
    border-bottom:1px solid #eef3f5;
    color:#111820 !important;
    font-size:15px;
  }
  .nav-links a:last-child{
    border-bottom:0;
  }
}

/* General page typography */
@media(max-width:700px){
  .page{
    padding-left:4vw !important;
    padding-right:4vw !important;
  }
  h1{
    font-size:clamp(36px,12vw,54px) !important;
    line-height:.95 !important;
  }
  h2{
    font-size:clamp(28px,9vw,42px) !important;
    line-height:1 !important;
  }
  p{
    font-size:16px;
  }
  .section-head,
  .section-head.uf{
    display:block !important;
  }
  .section-head a,
  .section-head.uf a{
    display:inline-block;
    margin-top:10px;
  }
}

/* Homepage */
@media(max-width:900px){
  .hero,
  .home-hero,
  .hero-grid,
  .home-hero-grid{
    grid-template-columns:1fr !important;
    padding:34px 4vw !important;
    min-height:auto !important;
  }
  .hero h1,
  .home-hero h1{
    font-size:clamp(44px,14vw,68px) !important;
  }
  .hero-actions,
  .button-row{
    flex-direction:column;
    align-items:stretch;
  }
  .hero-actions a,
  .button-row a,
  .btn{
    width:100%;
    justify-content:center;
    text-align:center;
  }
  .social-feed-layout{
    grid-template-columns:1fr !important;
  }
  .feed-side-panel{
    position:static !important;
  }
  .feed-card,
  .home-live-embed{
    padding:18px !important;
  }
  .feed-card-header{
    display:block !important;
  }
  .feed-card-header a{
    display:inline-block;
    margin-top:10px;
  }
  .home-gallery-grid{
    grid-template-columns:1fr !important;
  }
}

/* Roster page */
@media(max-width:900px){
  .roster-controls,
  .roster-toolbar,
  .filter-row{
    flex-direction:column !important;
    align-items:stretch !important;
    gap:10px !important;
  }
  .roster-controls select,
  .roster-toolbar select,
  .filter-row select,
  .roster-controls button,
  .roster-toolbar button,
  .filter-row button{
    width:100% !important;
    min-width:0 !important;
  }
  .roster-row{
    grid-template-columns:64px 1fr !important;
    gap:14px !important;
    padding:16px !important;
  }
  .roster-row .player-location,
  .roster-row .roster-actions,
  .roster-row .player-school,
  .roster-row .player-meta-right{
    grid-column:1 / -1;
    margin-left:0 !important;
  }
  .roster-row .headshot{
    width:62px !important;
    height:62px !important;
  }
  .roster-row h3,
  .roster-row .player-name{
    font-size:20px !important;
  }
  .roster-row .meta,
  .roster-row .player-meta{
    display:flex !important;
    flex-wrap:wrap;
    gap:8px !important;
  }
}
@media(max-width:600px){
  .roster-list.grid-view,
  .roster-grid{
    grid-template-columns:1fr !important;
  }
}

/* Player profile pages */
@media(max-width:900px){
  .player-hero,
  .profile-hero,
  .player-page-layout,
  .player-detail-layout{
    grid-template-columns:1fr !important;
  }
  .player-hero img,
  .profile-hero img,
  .player-photo,
  .profile-photo{
    max-height:360px;
    width:100%;
    object-fit:cover;
  }
  .player-bio-grid,
  .player-stats-grid,
  .bio-grid{
    grid-template-columns:1fr !important;
  }
}

/* Schedule page */
@media(max-width:1100px){
  .schedule-layout{
    grid-template-columns:1fr !important;
  }
  .schedule-side-card{
    position:static !important;
  }
}
@media(max-width:800px){
  .schedule-title h1{
    padding-left:12px !important;
  }
  .schedule-toolbar{
    display:block !important;
  }
  .schedule-toolbar select{
    width:100% !important;
    min-width:0 !important;
    margin-bottom:12px;
  }
  .schedule-month-tabs{
    display:flex !important;
    overflow-x:auto;
    flex-wrap:nowrap !important;
    gap:8px;
    padding-bottom:8px;
    -webkit-overflow-scrolling:touch;
  }
  .schedule-month-tabs button{
    flex:0 0 auto;
    min-width:96px;
  }
  .schedule-summary-grid{
    grid-template-columns:1fr 1fr !important;
  }
  .official-game-card{
    grid-template-columns:68px 1fr !important;
    gap:0 !important;
  }
  .official-game-card .game-date-box{
    min-height:96px !important;
  }
  .official-game-card .game-info{
    padding:14px !important;
  }
  .official-game-card .game-info h3{
    font-size:20px !important;
  }
  .official-game-card .game-result-box{
    grid-column:1 / -1;
    display:flex;
    align-items:center;
    justify-content:space-between;
    border-top:1px solid #dce5ea;
    padding:12px 16px !important;
  }
  .official-game-card .game-card-actions{
    grid-column:1 / -1;
    grid-template-columns:1fr !important;
    padding:12px 16px !important;
  }
  .schedule-table-card{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
}
@media(max-width:520px){
  .schedule-summary-grid{
    grid-template-columns:1fr !important;
  }
}

/* Individual game recap pages */
@media(max-width:1000px){
  .game-article-layout{
    grid-template-columns:1fr !important;
  }
  .article-side{
    position:static !important;
  }
}
@media(max-width:700px){
  .game-recap-page{
    padding:28px 4vw 46px !important;
  }
  .game-story-header{
    padding:20px !important;
  }
  .game-story-header h1{
    font-size:clamp(34px,12vw,54px) !important;
  }
  .game-score-hero{
    grid-template-columns:1fr !important;
    padding:20px !important;
  }
  .team-side span{
    font-size:44px !important;
  }
  .score-center strong{
    font-size:34px !important;
  }
  .game-action-row{
    display:grid !important;
    grid-template-columns:1fr !important;
    padding:18px 20px 0 !important;
  }
  .game-content-card{
    margin:20px !important;
    padding:18px !important;
  }
  .mini-box-score{
    grid-template-columns:1fr !important;
  }
  .line-score-scroll{
    overflow-x:auto;
  }
}

/* Stats page */
@media(max-width:900px){
  .stats-controls,
  .stats-tabs,
  .stats-toolbar{
    display:flex !important;
    overflow-x:auto;
    flex-wrap:nowrap !important;
    gap:10px;
    padding-bottom:8px;
    -webkit-overflow-scrolling:touch;
  }
  .stats-controls select,
  .stats-tabs button,
  .stats-toolbar button{
    flex:0 0 auto;
  }
  .leader-grid,
  .stats-leader-grid{
    grid-template-columns:1fr !important;
  }
  .stats-table-wrap,
  .table-card,
  .stats-table-card{
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch;
  }
}

/* Media page */
@media(max-width:800px){
  .media-hero-clean{
    grid-template-columns:1fr !important;
    padding:22px !important;
  }
  .media-hero-clean aside{
    display:none !important;
  }
  .media-album-copy{
    padding:18px !important;
  }
  .lightroom-embed-wrap{
    padding-bottom:70% !important;
  }
}

/* Sponsors / contact / tryout */
@media(max-width:900px){
  .sponsor-grid,
  .packages-grid,
  .contact-grid,
  .tryout-grid,
  .signup-grid{
    grid-template-columns:1fr !important;
  }
  .sponsor-card,
  .package-card,
  .contact-card{
    padding:20px !important;
  }
}

/* Embeds */
@media(max-width:700px){
  .instagram-home-embed .instagram-media,
  .tiktok-home-embed .tiktok-embed{
    min-width:0 !important;
    width:100% !important;
    max-width:100% !important;
  }
  .social-embed-shell,
  .instagram-shell,
  .tiktok-shell,
  .embed-widget-wrap{
    padding:8px !important;
  }
}

/* Footer */
@media(max-width:850px){
  .footer{
    padding:24px 4vw !important;
  }
  .footer-brand{
    display:grid !important;
    grid-template-columns:70px 1fr !important;
    gap:12px !important;
    align-items:center;
  }
  .footer-logo{
    width:66px !important;
    height:66px !important;
    object-fit:contain;
  }
  .mabl-inline{
    max-width:94px;
    height:auto;
  }
  .footer-icon-links{
    width:100%;
    justify-content:flex-start;
    margin-top:18px;
  }
  .official-footer-clean{
    padding:18px 4vw !important;
  }
  .official-footer-inner{
    display:block !important;
  }
  .official-footer-clean nav{
    margin-top:10px;
  }
}


/* === ATL Marlins Website V49: sticky desktop/mobile header restored === */
.main-nav{
  position:sticky !important;
  top:0 !important;
  z-index:5000 !important;
  background:#ffffff !important;
  box-shadow:0 1px 0 rgba(0,0,0,.08) !important;
}
body{
  overflow-x:hidden;
}
@media(min-width:901px){
  .main-nav{
    position:sticky !important;
    top:0 !important;
  }
}
@media(max-width:900px){
  .main-nav{
    position:sticky !important;
    top:0 !important;
  }
  .nav-links{
    z-index:5001 !important;
  }
}


/* === ATL Marlins Website V50: focused mobile fixes for roster + schedule === */

/* Hard stop horizontal overflow on phones */
@media(max-width:900px){
  html, body{
    width:100% !important;
    max-width:100% !important;
    overflow-x:hidden !important;
  }
  main, section, article, aside, div{
    max-width:100%;
  }
}

/* ROSTER MOBILE: rebuild rows as clean stacked cards */
@media(max-width:760px){
  .roster-page,
  .roster-page-v2,
  .roster-page-v3{
    padding-left:4vw !important;
    padding-right:4vw !important;
  }

  .roster-list{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:16px !important;
  }

  .roster-row{
    display:grid !important;
    grid-template-columns:86px minmax(0,1fr) !important;
    grid-auto-rows:auto !important;
    gap:0 16px !important;
    align-items:start !important;
    width:100% !important;
    min-height:0 !important;
    height:auto !important;
    padding:18px !important;
    border-radius:16px !important;
    overflow:hidden !important;
    position:relative !important;
  }

  .roster-row .headshot{
    grid-column:1 !important;
    grid-row:1 / span 2 !important;
    width:78px !important;
    height:78px !important;
    min-width:78px !important;
    border-radius:50% !important;
    margin:0 !important;
    align-self:start !important;
  }

  .roster-row .headshot img{
    width:100% !important;
    height:100% !important;
    object-fit:cover !important;
    border-radius:50% !important;
  }

  .roster-row .jersey-bubble{
    right:-5px !important;
    bottom:-4px !important;
    min-width:34px !important;
    height:34px !important;
    font-size:14px !important;
    z-index:4 !important;
  }

  /* main text block */
  .roster-row .player-main,
  .roster-row .roster-player-main,
  .roster-row .player-info,
  .roster-row .roster-info{
    grid-column:2 !important;
    grid-row:1 !important;
    min-width:0 !important;
    width:100% !important;
  }

  .roster-row h3,
  .roster-row .player-name,
  .roster-row .roster-name{
    font-size:26px !important;
    line-height:1.02 !important;
    letter-spacing:-.04em !important;
    margin:0 0 8px !important;
    color:#005a7c !important;
    word-break:normal !important;
  }

  .roster-row .meta,
  .roster-row .player-meta,
  .roster-row .roster-meta{
    display:flex !important;
    flex-wrap:wrap !important;
    align-items:center !important;
    gap:6px 10px !important;
    margin:0 !important;
    color:#5d6b75 !important;
    font-size:15px !important;
    line-height:1.35 !important;
  }

  .roster-row .meta span,
  .roster-row .player-meta span,
  .roster-row .roster-meta span{
    display:inline-flex !important;
    align-items:center !important;
    white-space:nowrap !important;
    margin:0 !important;
  }

  .roster-row .meta span::after,
  .roster-row .player-meta span::after,
  .roster-row .roster-meta span::after{
    display:none !important;
  }

  /* location/school block */
  .roster-row .player-location,
  .roster-row .roster-location,
  .roster-row .location-school,
  .roster-row .player-school,
  .roster-row .roster-school,
  .roster-row .player-meta-right{
    grid-column:1 / -1 !important;
    grid-row:auto !important;
    margin:16px 0 0 !important;
    padding:0 !important;
    width:100% !important;
    min-width:0 !important;
    position:static !important;
    transform:none !important;
    color:#111820 !important;
    font-size:16px !important;
    line-height:1.45 !important;
  }

  .roster-row .player-location p,
  .roster-row .roster-location p,
  .roster-row .player-school p,
  .roster-row .roster-school p,
  .roster-row .player-meta-right p{
    margin:0 0 5px !important;
    color:#111820 !important;
    white-space:normal !important;
  }

  /* action links */
  .roster-row .roster-actions,
  .roster-row .player-actions,
  .roster-row .player-links,
  .roster-row .actions{
    grid-column:1 / -1 !important;
    grid-row:auto !important;
    margin:18px 0 0 !important;
    padding:14px 0 0 !important;
    border-top:1px solid #e5edf1 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:12px !important;
    width:100% !important;
    position:static !important;
  }

  .roster-row a[href*="instagram"],
  .roster-row .mini-social{
    width:40px !important;
    height:40px !important;
    border-radius:999px !important;
    flex:0 0 auto !important;
  }

  .roster-row a[href*="players"],
  .roster-row .full-bio,
  .roster-row .bio-link{
    margin-left:auto !important;
    font-size:18px !important;
    font-weight:1000 !important;
    white-space:nowrap !important;
  }

  /* prevent desktop columns from bleeding through */
  .roster-row > *{
    max-width:100% !important;
  }
}

/* Extra small roster tightening */
@media(max-width:430px){
  .roster-row{
    grid-template-columns:76px minmax(0,1fr) !important;
    gap:0 14px !important;
    padding:16px !important;
  }
  .roster-row .headshot{
    width:70px !important;
    height:70px !important;
    min-width:70px !important;
  }
  .roster-row h3,
  .roster-row .player-name,
  .roster-row .roster-name{
    font-size:24px !important;
  }
  .roster-row .meta,
  .roster-row .player-meta,
  .roster-row .roster-meta{
    font-size:14px !important;
  }
}

/* SCHEDULE MOBILE: remove sidebar overflow and make table scroll properly */
@media(max-width:900px){
  .schedule-layout{
    display:block !important;
  }

  .schedule-main,
  .schedule-side-card,
  .related-news.schedule-side-card{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
  }

  .related-news.schedule-side-card{
    margin-top:28px !important;
    overflow:hidden !important;
    padding:20px !important;
  }

  .related-news.schedule-side-card h2{
    font-size:32px !important;
    line-height:1 !important;
    word-break:normal !important;
  }

  .related-news.schedule-side-card article{
    display:grid !important;
    grid-template-columns:54px minmax(0,1fr) !important;
    gap:14px !important;
    align-items:center !important;
    width:100% !important;
    max-width:100% !important;
    overflow:hidden !important;
  }

  .related-news.schedule-side-card article a{
    font-size:19px !important;
    line-height:1.15 !important;
    white-space:normal !important;
    overflow-wrap:anywhere !important;
    max-width:100% !important;
  }

  .related-news.schedule-side-card .news-thumb{
    width:54px !important;
    height:54px !important;
    min-width:54px !important;
  }

  .schedule-table-card{
    width:100% !important;
    max-width:100% !important;
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch !important;
  }

  .schedule-table,
  .official-schedule-table{
    min-width:720px !important;
    width:720px !important;
  }

  .schedule-table th,
  .schedule-table td{
    white-space:nowrap !important;
    font-size:14px !important;
    padding:12px !important;
  }
}

/* Make official game cards less huge and more readable on mobile */
@media(max-width:760px){
  .official-game-list{
    gap:16px !important;
  }

  .official-game-card{
    display:grid !important;
    grid-template-columns:64px minmax(0,1fr) !important;
    width:100% !important;
    max-width:100% !important;
    overflow:hidden !important;
    border-radius:16px !important;
  }

  .official-game-card .game-date-box{
    width:64px !important;
    min-height:90px !important;
    padding:10px 6px !important;
  }

  .official-game-card .game-date-box strong{
    font-size:26px !important;
  }

  .official-game-card .game-info{
    padding:14px !important;
    min-width:0 !important;
  }

  .official-game-card .game-info h3{
    font-size:20px !important;
    line-height:1.1 !important;
    white-space:normal !important;
    overflow-wrap:anywhere !important;
  }

  .official-game-card .game-info p,
  .official-game-card .game-info small{
    font-size:13px !important;
    white-space:normal !important;
  }

  .official-game-card .game-result-box{
    grid-column:1 / -1 !important;
    display:flex !important;
    justify-content:space-between !important;
    align-items:center !important;
    padding:12px 14px !important;
    border-top:1px solid #dce5ea !important;
  }

  .official-game-card .game-result-box strong{
    font-size:28px !important;
  }

  .official-game-card .game-card-actions{
    grid-column:1 / -1 !important;
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:8px !important;
    padding:12px 14px 16px !important;
  }

  .official-game-card .game-card-actions a{
    min-height:44px !important;
    font-size:15px !important;
  }
}

/* Keep browser bottom bar from covering last content too badly on iOS */
@media(max-width:760px){
  body{
    padding-bottom:env(safe-area-inset-bottom);
  }
  .official-footer-clean{
    padding-bottom:calc(18px + env(safe-area-inset-bottom)) !important;
  }
}


/* === ATL Marlins Website V51: roster mobile card rebuild fix === */
/* The roster markup uses .roster-main > .headshot + .roster-id.
   V50 targeted the nested items as if they were direct grid children, which caused overlap.
   This override rebuilds the actual structure cleanly. */

@media(max-width:760px){

  /* Always force a clean list layout on phones, even if grid view was selected */
  .roster-list,
  .roster-list.grid-view,
  .roster-grid{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:16px !important;
  }

  .roster-list.grid-view .roster-row,
  .roster-row{
    display:block !important;
    width:100% !important;
    max-width:100% !important;
    min-height:0 !important;
    height:auto !important;
    padding:0 !important;
    border-radius:16px !important;
    overflow:hidden !important;
    background:#ffffff !important;
    border:1px solid #dce5ea !important;
    box-shadow:0 8px 24px rgba(0,0,0,.05) !important;
  }

  /* Top section: photo left, player name/meta right */
  .roster-row .roster-main{
    display:grid !important;
    grid-template-columns:82px minmax(0,1fr) !important;
    gap:16px !important;
    align-items:center !important;
    width:100% !important;
    max-width:100% !important;
    padding:18px 18px 10px !important;
    margin:0 !important;
  }

  .roster-row .headshot,
  .roster-list.grid-view .roster-row .headshot{
    grid-column:1 !important;
    grid-row:1 !important;
    width:78px !important;
    height:78px !important;
    min-width:78px !important;
    max-width:78px !important;
    border-radius:999px !important;
    margin:0 !important;
    align-self:start !important;
    background-size:cover !important;
    background-position:center !important;
    overflow:visible !important;
  }

  .roster-row .roster-id{
    grid-column:2 !important;
    grid-row:1 !important;
    min-width:0 !important;
    width:100% !important;
    padding:0 !important;
    margin:0 !important;
  }

  .roster-row .player-name{
    display:block !important;
    font-size:24px !important;
    line-height:1.06 !important;
    letter-spacing:-.035em !important;
    margin:0 0 8px !important;
    color:#005a7c !important;
    white-space:normal !important;
    overflow-wrap:normal !important;
    word-break:normal !important;
  }

  .roster-row .player-meta{
    display:flex !important;
    flex-wrap:wrap !important;
    align-items:center !important;
    gap:5px 0 !important;
    margin:0 !important;
    color:#5d6b75 !important;
    font-size:15px !important;
    line-height:1.35 !important;
    font-weight:900 !important;
  }

  .roster-row .player-meta strong,
  .roster-row .player-meta span{
    display:inline-flex !important;
    align-items:center !important;
    padding:0 9px 0 0 !important;
    margin:0 9px 0 0 !important;
    border-right:1px solid #dce5ea !important;
    white-space:nowrap !important;
  }

  .roster-row .player-meta strong:last-child,
  .roster-row .player-meta span:last-child{
    border-right:0 !important;
  }

  .roster-row .jersey-bubble{
    right:-4px !important;
    bottom:-4px !important;
    min-width:34px !important;
    height:34px !important;
    padding:0 7px !important;
    border-radius:999px !important;
    border:3px solid #ffffff !important;
    background:#009fc3 !important;
    color:#ffffff !important;
    font-size:14px !important;
    font-weight:1000 !important;
    z-index:5 !important;
    box-shadow:0 6px 16px rgba(0,0,0,.18) !important;
  }

  /* Middle section: hometown + school full width */
  .roster-row .roster-location{
    display:block !important;
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    padding:6px 18px 16px !important;
    margin:0 !important;
    position:static !important;
    transform:none !important;
    color:#111820 !important;
    font-size:16px !important;
    line-height:1.4 !important;
    border:0 !important;
  }

  .roster-row .roster-location span{
    display:block !important;
    color:#111820 !important;
    font-weight:500 !important;
    white-space:normal !important;
    margin:0 0 6px !important;
    overflow-wrap:break-word !important;
  }

  .roster-row .roster-location p{
    display:block !important;
    color:#5d6b75 !important;
    margin:0 !important;
    font-weight:700 !important;
    white-space:normal !important;
    overflow-wrap:break-word !important;
  }

  /* Bottom section: instagram left, full bio right */
  .roster-row .roster-actions,
  .roster-row .mobile-generated-actions{
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:12px !important;
    width:100% !important;
    max-width:100% !important;
    padding:14px 18px 16px !important;
    margin:0 !important;
    border-top:1px solid #e6edf1 !important;
    background:#ffffff !important;
    position:static !important;
  }

  .roster-row .mini-social{
    width:42px !important;
    height:42px !important;
    min-width:42px !important;
    border-radius:999px !important;
    margin:0 !important;
  }

  .roster-row .bio-link{
    margin-left:auto !important;
    font-size:18px !important;
    line-height:1 !important;
    font-weight:1000 !important;
    color:#005a7c !important;
    white-space:nowrap !important;
  }

  /* Do not allow any old grid placement rules to move nested content */
  .roster-row .roster-main > *,
  .roster-row .roster-id > *,
  .roster-row .roster-location > *,
  .roster-row .roster-actions > *{
    max-width:100% !important;
  }
}

@media(max-width:420px){
  .roster-row .roster-main{
    grid-template-columns:74px minmax(0,1fr) !important;
    gap:14px !important;
    padding:16px 16px 8px !important;
  }
  .roster-row .headshot,
  .roster-list.grid-view .roster-row .headshot{
    width:70px !important;
    height:70px !important;
    min-width:70px !important;
    max-width:70px !important;
  }
  .roster-row .player-name{
    font-size:22px !important;
  }
  .roster-row .player-meta{
    font-size:14px !important;
  }
  .roster-row .roster-location{
    padding:6px 16px 14px !important;
  }
  .roster-row .roster-actions{
    padding:13px 16px 15px !important;
  }
}


/* === ATL Marlins Website V53: roster name locked beside photo + publishing placeholder cleanup === */

/* Desktop and mobile: identity always lives beside the headshot */
.roster-row .roster-main{
  display:grid !important;
  grid-template-columns:auto minmax(0,1fr) !important;
  align-items:center !important;
  gap:16px !important;
}
.roster-row .roster-id{
  min-width:0 !important;
  display:block !important;
}
.roster-row .player-name{
  display:block !important;
  position:static !important;
  visibility:visible !important;
  opacity:1 !important;
  color:#005a7c !important;
  text-decoration:none !important;
  text-align:left !important;
  margin:0 0 7px !important;
  white-space:normal !important;
}
.roster-row .roster-actions .player-name,
.roster-row .roster-actions a.player-name,
.roster-row .roster-actions .roster-name{
  display:none !important;
}
.roster-row .roster-actions{
  display:flex !important;
  align-items:center !important;
  gap:16px !important;
}
.roster-row .roster-actions .bio-link{
  margin-left:auto !important;
}

/* Mobile roster card modeled closer to UF: photo/name/meta on top, details below */
@media(max-width:760px){
  .roster-list,
  .roster-list.grid-view,
  .roster-grid{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:16px !important;
  }

  .roster-row,
  .roster-list.grid-view .roster-row{
    display:block !important;
    padding:0 !important;
    overflow:hidden !important;
    border-radius:16px !important;
    background:#ffffff !important;
  }

  .roster-row .roster-main{
    display:grid !important;
    grid-template-columns:82px minmax(0,1fr) !important;
    gap:16px !important;
    align-items:center !important;
    padding:18px 18px 10px !important;
    margin:0 !important;
  }

  .roster-row .headshot{
    width:78px !important;
    height:78px !important;
    min-width:78px !important;
    max-width:78px !important;
    grid-column:1 !important;
    grid-row:1 !important;
    margin:0 !important;
    align-self:start !important;
  }

  .roster-row .roster-id{
    grid-column:2 !important;
    grid-row:1 !important;
    min-width:0 !important;
    padding:0 !important;
    margin:0 !important;
  }

  .roster-row .player-name{
    font-size:25px !important;
    line-height:1.05 !important;
    letter-spacing:-.04em !important;
    margin:0 0 10px !important;
  }

  .roster-row .player-meta{
    display:flex !important;
    flex-wrap:wrap !important;
    align-items:center !important;
    gap:5px 0 !important;
    font-size:15px !important;
    line-height:1.35 !important;
  }

  .roster-row .player-meta strong,
  .roster-row .player-meta span{
    display:inline-flex !important;
    align-items:center !important;
    white-space:nowrap !important;
    margin:0 8px 0 0 !important;
    padding:0 8px 0 0 !important;
    border-right:1px solid #dce5ea !important;
  }

  .roster-row .player-meta strong:last-child,
  .roster-row .player-meta span:last-child{
    border-right:0 !important;
  }

  .roster-row .roster-location{
    display:block !important;
    padding:8px 18px 16px !important;
    margin:0 !important;
    width:100% !important;
    position:static !important;
    transform:none !important;
    font-size:16px !important;
    line-height:1.4 !important;
  }

  .roster-row .roster-location span,
  .roster-row .roster-location p{
    display:block !important;
    white-space:normal !important;
    overflow-wrap:break-word !important;
    margin:0 0 6px !important;
  }

  .roster-row .roster-actions{
    padding:14px 18px 16px !important;
    margin:0 !important;
    border-top:1px solid #e6edf1 !important;
    justify-content:flex-start !important;
    gap:18px !important;
  }

  .roster-row .roster-actions .bio-link{
    margin-left:0 !important;
    font-size:18px !important;
    white-space:nowrap !important;
  }
}

@media(max-width:420px){
  .roster-row .roster-main{
    grid-template-columns:76px minmax(0,1fr) !important;
    gap:14px !important;
    padding:16px 16px 10px !important;
  }
  .roster-row .headshot{
    width:70px !important;
    height:70px !important;
    min-width:70px !important;
    max-width:70px !important;
  }
  .roster-row .player-name{
    font-size:23px !important;
  }
}

/* Hide publishing placeholders/empty coming-soon blocks without deleting real completed content */
.placeholder,
.coming-soon,
[data-placeholder="true"]{
  display:none !important;
}


/* === ATL Marlins Website V54: sticky header fixed for desktop and mobile === */
/* Use fixed positioning instead of sticky because some page sections/embeds can break sticky behavior. */

:root{
  --top-strip-height: 42px;
  --main-nav-height: 116px;
  --fixed-header-offset: calc(var(--top-strip-height) + var(--main-nav-height));
}

body{
  padding-top: var(--fixed-header-offset) !important;
}

.top-strip{
  position:fixed !important;
  top:0 !important;
  left:0 !important;
  right:0 !important;
  height:var(--top-strip-height) !important;
  z-index:9000 !important;
}

.main-nav{
  position:fixed !important;
  top:var(--top-strip-height) !important;
  left:0 !important;
  right:0 !important;
  min-height:var(--main-nav-height) !important;
  z-index:8999 !important;
  background:#ffffff !important;
  box-shadow:0 1px 0 rgba(0,0,0,.10), 0 8px 24px rgba(0,0,0,.04) !important;
}

.main-nav .nav-links{
  z-index:9010 !important;
}

@media(max-width:900px){
  :root{
    --top-strip-height: 0px;
    --main-nav-height: 76px;
    --fixed-header-offset: var(--main-nav-height);
  }

  .top-strip{
    display:none !important;
  }

  body{
    padding-top:var(--fixed-header-offset) !important;
  }

  .main-nav{
    top:0 !important;
    min-height:var(--main-nav-height) !important;
    height:auto !important;
    z-index:9000 !important;
  }

  .nav-links{
    position:fixed !important;
    top:calc(var(--main-nav-height) + 8px) !important;
    left:4vw !important;
    right:4vw !important;
    z-index:9010 !important;
  }
}

[id]{
  scroll-margin-top:calc(var(--fixed-header-offset) + 18px);
}
