/* ===============================
   LAKEFRONT SPORTS — WHITE SOX ZONE v13
   Design system matching homepage v37
   Colors: White Sox Charcoal #27251f, Silver #c4ced4
================================ */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Manrope:wght@400;600;700;800;900&display=swap');

:root {
  --navy:#081b2e;--navy-2:#0c243b;--red:#cc3433;--red-glow:rgba(204,52,51,0.3);--sidebar-w:260px;--topbar-h:52px;--radius:12px;
  --bears-primary:#0b162a;--bears-accent:#c83803;--bears-border:#e5392d;--blackhawks-primary:#000;--blackhawks-accent:#cf0a2c;--blackhawks-border:#caa75c;--bulls-primary:#000;--bulls-accent:#ce1141;--bulls-border:#ce1141;--cubs-primary:#0e3386;--cubs-accent:#cc3433;--cubs-border:#cc3433;--whitesox-primary:#27251f;--whitesox-accent:#c4ced4;--whitesox-border:#c4ced4;
}
[data-theme="light"]{--bg:#f5f5f3;--text:#0d1b2a;--card:#fff;--muted:#6b7c8f;--card-border:rgba(0,0,0,0.06);--card-shadow:0 2px 8px rgba(0,0,0,0.05);--card-shadow-hover:0 8px 24px rgba(0,0,0,0.12);}
[data-theme="dark"]{--bg:#0a0a0f;--text:#e8e8e8;--card:#151520;--muted:#7a8899;--card-border:rgba(255,255,255,0.06);--card-shadow:0 2px 8px rgba(0,0,0,0.2);--card-shadow-hover:0 8px 24px rgba(0,0,0,0.35);}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}html{scroll-behavior:smooth;}body{font-family:'Manrope',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;overflow-x:clip;min-height:100vh;width:100%;}img{max-width:100%;display:block;}a{text-decoration:none;color:inherit;}.app-shell{display:flex;min-height:100vh;width:100%;}

/* SIDEBAR — White Sox charcoal/black gradient */
.sidebar{width:var(--sidebar-w);position:fixed;top:0;left:0;bottom:0;z-index:90;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;transition:background 0.45s ease,border-color 0.45s ease,box-shadow 0.45s ease;background:linear-gradient(135deg,#27251f 0%,#000 100%);border-right:4px solid #c4ced4;box-shadow:4px 0 20px rgba(0,0,0,0.3);}
.sidebar::-webkit-scrollbar{width:3px;}.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:3px;}
.sidebar.sidebar-whitesox{background:linear-gradient(135deg,#27251f 0%,#000 100%);border-right-color:#c4ced4;}
.sidebar-brand{padding:14px 16px 10px;border-bottom:1px solid rgba(255,255,255,0.07);}.sidebar-logo{height:44px;width:auto;transition:transform 0.3s ease;}.sidebar-logo:hover{transform:scale(1.03);}
.sidebar-theme{padding:7px 12px;border-bottom:1px solid rgba(255,255,255,0.05);}.theme-toggle-btn{width:100%;padding:5px 8px;border-radius:6px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06);color:rgba(255,255,255,0.5);font:600 10px 'Manrope',sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:all 0.2s;}.theme-toggle-btn:hover{background:rgba(255,255,255,0.08);color:#fff;}
.sidebar-nav{flex:1;padding:4px 0;}.nav-section-label{padding:7px 16px 2px;font-size:9px;font-weight:800;letter-spacing:0.13em;color:rgba(255,255,255,0.18);text-transform:uppercase;}
.sidebar-nav-item{display:flex;align-items:center;gap:8px;padding:7px 16px;color:rgba(255,255,255,0.48);font-size:12px;font-weight:600;cursor:pointer;transition:all 0.12s;text-decoration:none;border-left:3px solid transparent;}.sidebar-nav-item:hover{color:#fff;background:rgba(255,255,255,0.03);}.sidebar-nav-item.active{color:#fff;background:rgba(255,255,255,0.05);border-left-color:var(--whitesox-accent);}
.sidebar-nav-item .nav-icon{font-size:14px;width:16px;text-align:center;}.sidebar-nav-item .nav-chevron{margin-left:auto;font-size:8px;color:rgba(255,255,255,0.15);transition:transform 0.2s;}.sidebar-nav-item .nav-chevron.open{transform:rotate(90deg);}.sidebar-nav-item .nav-badge{margin-left:auto;font-size:8px;font-weight:800;background:rgba(196,206,212,0.3);color:#fff;padding:1px 5px;border-radius:2px;}
.subnav{overflow:hidden;transition:max-height 0.25s ease;max-height:0;background:rgba(0,0,0,0.25);}.subnav a{display:block;padding:4px 16px 4px 44px;font-size:10px;font-weight:600;color:rgba(255,255,255,0.28);text-decoration:none;transition:all 0.1s;}.subnav a:hover{color:#fff;background:rgba(255,255,255,0.03);}.subnav .zone-link{color:rgba(255,255,255,0.5);font-weight:700;border-top:1px solid rgba(255,255,255,0.06);padding-top:5px;margin-top:2px;}.subnav .zone-link.active-zone{color:var(--whitesox-accent);}
.todays-games{padding:9px 14px;border-top:1px solid rgba(255,255,255,0.05);}.todays-games-title{font-family:'Bebas Neue',sans-serif;font-size:14px;color:rgba(255,255,255,0.6);letter-spacing:0.5px;margin-bottom:5px;}.game-row{padding:5px 0;border-bottom:1px solid rgba(255,255,255,0.03);font-size:10px;color:rgba(255,255,255,0.4);}.game-row:last-child{border:none;}.game-teams{font-weight:700;color:rgba(255,255,255,0.65);}.game-status{font-size:9px;margin-top:1px;}.game-live{color:#4ade80;font-weight:800;}
.sidebar-social{padding:9px 16px;border-top:1px solid rgba(255,255,255,0.04);display:flex;gap:12px;justify-content:center;}.sidebar-social a{color:rgba(255,255,255,0.22);display:flex;transition:color 0.2s;}.sidebar-social a:hover{color:#fff;}

/* MAIN CONTENT */
.main-content{margin-left:var(--sidebar-w);flex:1;min-height:100vh;display:flex;flex-direction:column;overflow-x:clip;}
.hero-section,.promo-banner,.schedule-strip,.zone-widgets-row,.archive-section,.category-slot,.site-footer{max-width:960px;width:100%;margin-left:auto;margin-right:auto;}

/* RAIL PROMOS — White Sox charcoal colorways */
.promo-rail{position:absolute;top:20px;bottom:20px;width:160px;display:flex;flex-direction:column;justify-content:center;gap:14px;z-index:1;}.promo-rail-left{right:100%;margin-right:16px;}.promo-rail-right{left:100%;margin-left:16px;}
.promo-rail-card{border-radius:10px;padding:24px 16px;text-align:center;font-size:10px;font-weight:700;line-height:1.4;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.rail-write{background:linear-gradient(180deg,#27251f 0%,#000 100%);color:#fff;border:1px solid rgba(196,206,212,0.2);}
.rail-write .rail-title{font-size:20px;}.rail-write .rail-desc{font-size:12px;}
.rail-forum{background:linear-gradient(180deg,#1a1a1a 0%,#060606 100%);color:#fff;border:1px solid rgba(196,206,212,0.15);}
.rail-forum .rail-title{font-size:20px;}.rail-forum .rail-desc{font-size:12px;}
.rail-newsletter{background:linear-gradient(180deg,#27251f 0%,rgba(196,206,212,0.1) 100%);color:#fff;border:1px solid rgba(196,206,212,0.2);}
.rail-newsletter .rail-title{font-size:20px;}.rail-newsletter .rail-desc{font-size:12px;}
.rail-social{background:linear-gradient(180deg,#27251f 0%,#3a3830 100%);color:#fff;border:1px solid rgba(196,206,212,0.15);}
.rail-social .rail-title{font-size:20px;}.rail-social .rail-desc{font-size:12px;}
.rail-title{font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:0.5px;margin-bottom:10px;}.rail-desc{font-size:10px;opacity:0.7;font-weight:400;margin-bottom:12px;line-height:1.5;}
.rail-btn{display:inline-block;padding:7px 16px;border-radius:5px;font:700 10px 'Manrope',sans-serif;text-decoration:none;transition:all 0.2s;}
.rail-btn-charcoal{background:#27251f;color:#fff;border:1px solid rgba(255,255,255,0.15);}.rail-btn-charcoal:hover{background:#3a3830;}
.rail-btn-red{background:var(--red);color:#fff;}.rail-btn-red:hover{background:#e04444;transform:translateY(-1px);}
.rail-btn-silver{background:rgba(196,206,212,0.6);color:#000;}.rail-btn-silver:hover{background:rgba(196,206,212,0.85);transform:translateY(-1px);}
.rail-social-links{display:flex;gap:10px;justify-content:center;margin-top:8px;}.rail-social-links a{color:rgba(255,255,255,0.5);transition:color 0.2s;display:flex;}.rail-social-links a:hover{color:#fff;}
.rail-write .rail-btn-charcoal{background:#c4ced4;color:#27251f;}.rail-write .rail-btn-charcoal:hover{background:#d8dfe3;transform:translateY(-1px);}
@media(max-width:1440px){.promo-rail{display:none;}}

/* DESKTOP TOPBAR — silver/charcoal border */
.topbar-desk{height:var(--topbar-h);position:sticky;top:0;z-index:80;display:flex;align-items:center;justify-content:space-between;padding:0 22px;gap:12px;transition:all 0.35s;border-bottom:3px solid var(--whitesox-accent);backdrop-filter:blur(10px);}
[data-theme="light"] .topbar-desk{background:linear-gradient(135deg,#27251f,#000);color:#fff;}
[data-theme="light"] .topbar-desk .topbar-search{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.1);color:#fff;}
[data-theme="light"] .topbar-desk .topbar-search::placeholder{color:rgba(255,255,255,0.4);}
[data-theme="light"] .topbar-desk .topbar-btn-ghost{border-color:rgba(255,255,255,0.15);color:rgba(255,255,255,0.8);}
[data-theme="dark"] .topbar-desk{background:rgba(10,10,15,0.95);}
.topbar-search{padding:6px 12px;border-radius:6px;font:400 11px 'Manrope',sans-serif;border:1px solid var(--card-border);width:240px;background:transparent;color:var(--text);transition:all 0.2s;}.topbar-search:focus{outline:none;border-color:var(--whitesox-accent);box-shadow:0 0 0 3px rgba(196,206,212,0.12);}.topbar-search::placeholder{color:var(--muted);}
.topbar-actions{display:flex;align-items:center;gap:6px;}.topbar-btn{padding:5px 10px;border-radius:6px;font:700 9px 'Manrope',sans-serif;cursor:pointer;transition:all 0.2s;border:none;text-decoration:none;display:inline-flex;align-items:center;gap:3px;white-space:nowrap;}
.topbar-btn-ghost{background:transparent;border:1px solid var(--card-border);color:var(--text);}.topbar-btn-ghost:hover{border-color:var(--whitesox-accent);color:var(--whitesox-primary);}
[data-theme="dark"] .topbar-btn-ghost:hover{color:var(--whitesox-accent);}
.topbar-btn-primary{background:var(--whitesox-primary);color:#fff;border:1px solid var(--whitesox-accent);}.topbar-btn-primary:hover{background:#3a3830;transform:translateY(-1px);}

/* MOBILE HEADER — charcoal/black gradient, silver border */
.mobile-header{display:none;position:sticky;top:0;z-index:100;flex-direction:column;background:linear-gradient(135deg,#27251f 0%,#000 100%);border-bottom:3px solid #c4ced4;box-shadow:0 4px 16px rgba(0,0,0,0.3);width:100%;max-width:100vw;overflow:hidden;}
.mobile-header-top{display:flex;align-items:center;justify-content:space-between;padding:7px 12px;min-height:44px;}.mobile-logo{height:33px;width:auto;}.mobile-btn{background:none;border:none;color:#fff;font-size:18px;cursor:pointer;padding:3px;}
.mobile-actions{display:flex;align-items:center;gap:5px;padding:0 12px 7px;}.mobile-search{flex:1;min-width:0;padding:5px 10px;border-radius:6px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.06);color:#fff;font:400 10px 'Manrope',sans-serif;}.mobile-search::placeholder{color:rgba(255,255,255,0.25);}.mobile-search:focus{outline:none;border-color:var(--whitesox-accent);}
.mobile-cta{padding:5px 9px;border-radius:6px;background:var(--whitesox-accent);color:#27251f;font:700 9px 'Manrope',sans-serif;border:none;cursor:pointer;white-space:nowrap;text-decoration:none;}

/* MOBILE DRAWER — charcoal/black gradient */
.mobile-drawer{position:fixed;inset:0;z-index:200;transform:translateX(-100%);transition:transform 0.3s ease;background:linear-gradient(135deg,#27251f 0%,#000 100%);display:flex;flex-direction:column;overflow-y:auto;}.mobile-drawer.open{transform:translateX(0);}
.mobile-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,0.06);}.mobile-drawer-close{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;}.mobile-drawer-body{flex:1;padding:6px 0;overflow-y:auto;}

/* ZONE TITLE BAR — charcoal gradient, silver accent border */
.zone-title-bar{background:linear-gradient(135deg,#27251f 0%,#1a1715 100%);padding:0 22px;position:sticky;top:var(--topbar-h);z-index:70;}
.zone-title-inner{max-width:960px;margin:0 auto;display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:5px solid var(--whitesox-accent);}
.zone-title-icon{font-size:22px;}.zone-title-name{font-family:'Bebas Neue',sans-serif;font-size:44px;color:#fff;letter-spacing:2px;line-height:1;}.zone-title-sub{font-size:13px;font-weight:700;color:rgba(255,255,255,0.45);letter-spacing:0.5px;margin-left:auto;}

/* CAT SECTION HEADERS — charcoal gradient, silver accent */
.cat-section-header{background:linear-gradient(135deg,#27251f 0%,#1a1715 100%);padding:0 22px;margin-bottom:10px;}
.cat-section-header-inner{max-width:960px;margin:0 auto;display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:5px solid var(--whitesox-accent);}
.cat-section-icon{font-size:18px;}.cat-section-name{font-family:'Bebas Neue',sans-serif;font-size:42px;color:#fff;letter-spacing:2px;line-height:1;}
.cat-section-count{margin-left:auto;font-size:12px;font-weight:800;color:rgba(255,255,255,0.5);letter-spacing:0.5px;text-decoration:none;padding:4px 12px;border-radius:5px;border:1px solid rgba(255,255,255,0.15);transition:all 0.2s;}.cat-section-count:hover{color:#fff;border-color:rgba(255,255,255,0.4);background:rgba(255,255,255,0.06);}
.category-slot{padding:0 22px;}.category-slot:empty{display:none;}

/* HERO */
.hero-section{padding:18px 22px 10px;position:relative;overflow:visible;}
.hero-card{display:grid;grid-template-columns:1fr 1fr;border-radius:14px;overflow:hidden;min-height:340px;cursor:pointer;transition:box-shadow 0.3s;background:var(--card);box-shadow:var(--card-shadow);position:relative;text-decoration:none;color:var(--text);}.hero-card:hover{box-shadow:0 16px 50px rgba(0,0,0,0.25);}
.hero-image-wrap{position:relative;overflow:hidden;}.hero-image-wrap img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform 0.5s;}.hero-card:hover .hero-image-wrap img{transform:scale(1.03);}
.hero-body{padding:28px;display:flex;flex-direction:column;justify-content:center;}.hero-kicker{font-size:13px;font-weight:800;letter-spacing:0.14em;color:#fff;margin-bottom:6px;display:inline-flex;align-items:center;gap:4px;background:var(--whitesox-primary);padding:3px 10px;border-radius:4px;align-self:flex-start;}
.hero-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(26px,2.9vw,44px);line-height:1.05;letter-spacing:0.5px;margin-bottom:8px;}.hero-excerpt{font-size:15px;line-height:1.5;color:var(--muted);margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;}.hero-meta{font-size:13px;color:var(--muted);}
.hero-read-more{font-size:14px;font-weight:700;color:var(--whitesox-primary);margin-top:12px;display:inline-flex;align-items:center;gap:4px;transition:gap 0.2s;}
[data-theme="dark"] .hero-read-more{color:var(--whitesox-accent);}
.hero-card:hover .hero-read-more{gap:8px;}
.hero-recent{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px;}
.hero-recent-card{display:grid;grid-template-columns:100px 1fr;border-radius:10px;overflow:hidden;cursor:pointer;transition:all 0.22s;background:var(--card);box-shadow:var(--card-shadow);text-decoration:none;color:var(--text);}.hero-recent-card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover);}
.hero-recent-img{position:relative;overflow:hidden;min-height:100px;}.hero-recent-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform 0.4s;}.hero-recent-card:hover .hero-recent-img img{transform:scale(1.04);}
.hero-recent-accent{position:absolute;top:0;left:0;bottom:0;width:3px;z-index:2;background:linear-gradient(135deg,#27251f,#c4ced4);}
.hero-recent-body{padding:10px 12px;display:flex;flex-direction:column;justify-content:center;}.hero-recent-tag{display:inline-block;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:800;letter-spacing:0.06em;color:#fff;background:var(--whitesox-primary);margin-bottom:4px;align-self:flex-start;}.hero-recent-title{font-size:14px;font-weight:800;line-height:1.25;margin-bottom:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}.hero-recent-excerpt{font-size:11px;line-height:1.4;color:var(--muted);margin-bottom:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}.hero-recent-meta{font-size:11px;color:var(--muted);}
.hero-recent-read{font-size:12px;font-weight:700;color:var(--whitesox-primary);margin-top:4px;display:inline-flex;align-items:center;gap:3px;transition:gap 0.2s;}
[data-theme="dark"] .hero-recent-read{color:var(--whitesox-accent);}
.hero-recent-card:hover .hero-recent-read{gap:6px;}

/* SCHEDULE STRIP */
.schedule-strip{padding:0 22px;margin-bottom:14px;}.schedule-strip-inner{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;align-items:stretch;}
.schedule-card{border-radius:10px;padding:16px;background:var(--card);border:1px solid var(--card-border);text-align:center;transition:all 0.2s;}.schedule-card:hover{border-color:var(--whitesox-accent);box-shadow:0 4px 16px rgba(196,206,212,0.1);}
.schedule-label{font-size:11px;font-weight:800;letter-spacing:0.1em;color:var(--muted);text-transform:uppercase;margin-bottom:4px;}.schedule-opponent{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:0.5px;line-height:1.1;margin-bottom:2px;}.schedule-date{font-size:13px;color:var(--muted);font-weight:600;}.schedule-time{font-size:12px;color:var(--whitesox-primary);font-weight:700;margin-top:2px;}
[data-theme="dark"] .schedule-time{color:var(--whitesox-accent);}

/* ZONE WIDGETS ROW */
.zone-widgets-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:0 22px;margin-bottom:14px;max-width:960px;width:calc(100% - 44px);margin-left:auto;margin-right:auto;}
.zone-widget{border-radius:10px;padding:16px;background:var(--card);border:1px solid var(--card-border);box-shadow:var(--card-shadow);}
#calendar-widget{background:#2c2c2c;border-color:#1a1a1a;}
[data-theme="light"] #calendar-widget{background:#d4d8db;border-color:#b0b8be;}
#standings-widget{background:#2c2c2c;border-color:#1a1a1a;}
[data-theme="light"] #standings-widget{background:#d4d8db;border-color:#b0b8be;}
.zone-widget-title{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:0.5px;margin-bottom:8px;display:flex;align-items:center;gap:5px;padding-bottom:6px;border-bottom:2px solid var(--whitesox-primary);}
[data-theme="dark"] .zone-widget-title{border-bottom-color:var(--whitesox-accent);}
#calendar-widget .zone-widget-title,#standings-widget .zone-widget-title{border-bottom-color:rgba(255,255,255,0.2);color:#fff;}
[data-theme="light"] #calendar-widget .zone-widget-title,[data-theme="light"] #standings-widget .zone-widget-title{border-bottom-color:rgba(0,0,0,0.2);color:#111;}
.zone-widget-row{display:flex;justify-content:space-between;font-size:13px;padding:5px 0;border-bottom:1px solid var(--card-border);}.zone-widget-row:last-child{border:none;}.zone-widget-value{font-weight:700;}
/* Standings table grid */
.standings-header{display:grid;grid-template-columns:1fr 50px 40px 42px 40px 36px;font-size:10px;font-weight:800;letter-spacing:0.06em;color:rgba(255,255,255,0.35);text-transform:uppercase;padding:4px 0;border-bottom:1px solid rgba(255,255,255,0.1);}
[data-theme="light"] .standings-header{color:rgba(0,0,0,0.4);border-bottom-color:rgba(0,0,0,0.15);}
.standings-row{display:grid;grid-template-columns:1fr 50px 40px 42px 40px 36px;font-size:12px;padding:7px 0;border-bottom:1px solid rgba(255,255,255,0.07);align-items:center;color:rgba(255,255,255,0.75);}.standings-row:last-child{border:none;}
[data-theme="light"] .standings-row{border-bottom-color:rgba(0,0,0,0.1);color:rgba(0,0,0,0.7);}
.standings-row.whitesox-row{font-weight:800;color:#fff;}
[data-theme="light"] .standings-row.whitesox-row{color:#111;}
.standings-cell{text-align:center;font-weight:700;}.standings-team{text-align:left;}

/* CALENDAR WIDGET */
.calendar-month-label{font-family:'Bebas Neue',sans-serif;font-size:17px;letter-spacing:0.5px;text-align:center;margin-bottom:6px;display:flex;align-items:center;justify-content:center;gap:10px;color:#fff;}
[data-theme="light"] .calendar-month-label{color:#111;}
.calendar-nav-btn{background:none;border:1px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.6);width:22px;height:22px;border-radius:4px;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center;transition:all 0.2s;}.calendar-nav-btn:hover{border-color:#fff;color:#fff;}
[data-theme="light"] .calendar-nav-btn{border-color:rgba(0,0,0,0.25);color:rgba(0,0,0,0.6);}[data-theme="light"] .calendar-nav-btn:hover{border-color:#222;color:#111;}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:#111;}
[data-theme="light"] .calendar-grid{background:#9aa4ab;}
.calendar-day-header{font-size:10px;font-weight:800;letter-spacing:0.05em;text-transform:uppercase;color:rgba(255,255,255,0.35);text-align:center;padding:3px;background:#2c2c2c;}
[data-theme="light"] .calendar-day-header{color:rgba(0,0,0,0.4);background:#d4d8db;}
.calendar-day{text-align:center;padding:4px 2px;font-size:12px;position:relative;min-height:28px;display:flex;align-items:center;justify-content:center;flex-direction:column;background:#2c2c2c;color:rgba(255,255,255,0.75);}.calendar-day.other-month{background:#232323;color:rgba(255,255,255,0.2);}.calendar-day.today{background:#3e3e3e;font-weight:800;color:#fff;}.calendar-day.has-event{cursor:pointer;font-weight:700;color:#fff;}.calendar-day.has-event::after{content:'';width:5px;height:5px;border-radius:50%;position:absolute;bottom:2px;}.calendar-day.home-game::after{background:#f0f0f0;}.calendar-day.away-game::after{background:#111;box-shadow:0 0 0 1px rgba(255,255,255,0.3);}.calendar-day.has-event:hover{background:#3a3a3a;}.calendar-day.selected{background:#444 !important;color:#fff;font-weight:800;border:1px solid rgba(255,255,255,0.5);}
[data-theme="light"] .calendar-day{background:#d4d8db;color:rgba(0,0,0,0.7);}[data-theme="light"] .calendar-day.other-month{background:#c8cdd0;color:rgba(0,0,0,0.25);}[data-theme="light"] .calendar-day.today{background:#bfc5c9;font-weight:800;color:#000;}[data-theme="light"] .calendar-day.has-event{color:#000;}[data-theme="light"] .calendar-day.away-game::after{background:#111;box-shadow:none;}[data-theme="light"] .calendar-day.has-event:hover{background:#c5cacd;}[data-theme="light"] .calendar-day.selected{background:#b8bfc3 !important;border-color:rgba(0,0,0,0.4);}
.calendar-event-tooltip{position:absolute;bottom:100%;left:50%;transform:translateX(-50%);background:var(--whitesox-primary);color:#fff;padding:4px 8px;border-radius:4px;font-size:8px;font-weight:600;white-space:nowrap;z-index:10;pointer-events:none;opacity:0;transition:opacity 0.2s;}.calendar-day.has-event:hover .calendar-event-tooltip{opacity:1;}
.calendar-legend{display:flex;gap:10px;justify-content:center;margin-top:8px;flex-wrap:wrap;}.calendar-legend-item{display:flex;align-items:center;gap:3px;font-size:11px;color:rgba(255,255,255,0.45);}.calendar-legend-dot{width:5px;height:5px;border-radius:50%;background:#f0f0f0;}.calendar-legend-dot.away{background:#111;box-shadow:0 0 0 1px rgba(255,255,255,0.3);}
[data-theme="light"] .calendar-legend-item{color:rgba(0,0,0,0.45);}[data-theme="light"] .calendar-legend-dot.away{background:#111;box-shadow:none;}
.calendar-game-card{margin-top:10px;padding:12px 14px;border-radius:8px;background:#1e1e1e;border:1px solid #111;border-left:3px solid #f0f0f0;min-height:62px;display:flex;flex-direction:column;justify-content:center;transition:all 0.25s;}[data-theme="light"] .calendar-game-card{background:#bfc5c9;border-color:#9aa4ab;border-left-color:#222;}.cal-game-card-empty{font-size:12px;color:rgba(255,255,255,0.3);text-align:center;opacity:0.55;font-style:italic;}[data-theme="light"] .cal-game-card-empty{color:rgba(0,0,0,0.4);}.cal-game-card-badge{font-size:10px;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.5);margin-bottom:5px;text-align:center;}[data-theme="light"] .cal-game-card-badge{color:rgba(0,0,0,0.5);}.cal-game-card-matchup{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:0.5px;line-height:1.15;margin-bottom:4px;color:#fff;text-align:center;}[data-theme="light"] .cal-game-card-matchup{color:#111;}.cal-game-card-details{font-size:12px;color:rgba(255,255,255,0.45);line-height:1.5;text-align:center;}[data-theme="light"] .cal-game-card-details{color:rgba(0,0,0,0.5);}

/* CATEGORY GRID & ARTICLE CARD */
.category-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:6px;}.category-load-more{text-align:center;padding:8px;}.category-load-more-btn{background:transparent;border:1px dashed var(--card-border);color:var(--muted);padding:8px 20px;border-radius:8px;font:700 13px 'Manrope',sans-serif;cursor:pointer;transition:all 0.2s;}.category-load-more-btn:hover{border-color:var(--whitesox-accent);color:var(--whitesox-primary);background:rgba(196,206,212,0.03);}
[data-theme="dark"] .category-load-more-btn:hover{color:var(--whitesox-accent);}
.article-card{display:grid;grid-template-columns:180px 1fr;border-radius:10px;overflow:hidden;cursor:pointer;text-decoration:none;color:var(--text);transition:all 0.22s;background:var(--card);box-shadow:var(--card-shadow);}.article-card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover);}
.article-card-image{position:relative;overflow:hidden;min-height:130px;}.article-card-image img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform 0.4s;}.article-card:hover .article-card-image img{transform:scale(1.04);}
.article-card-accent{position:absolute;top:0;left:0;bottom:0;width:3px;z-index:2;background:linear-gradient(135deg,#27251f,#c4ced4);}
.article-card-body{padding:14px 16px;display:flex;flex-direction:column;justify-content:center;}.article-card-tag{display:inline-block;padding:2px 7px;border-radius:3px;font-size:11px;font-weight:800;letter-spacing:0.06em;color:#fff;margin-bottom:5px;align-self:flex-start;background:var(--whitesox-primary);}
.article-card-title{font-size:16px;font-weight:800;line-height:1.25;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}.article-card-excerpt{font-size:13px;line-height:1.45;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}.article-card-meta{font-size:12px;color:var(--muted);margin-top:5px;}
.article-card-read{font-size:13px;font-weight:700;color:var(--whitesox-primary);margin-top:7px;display:inline-flex;align-items:center;gap:3px;transition:gap 0.2s;}
[data-theme="dark"] .article-card-read{color:var(--whitesox-accent);}
.article-card:hover .article-card-read{gap:6px;}
.article-card.featured-card{grid-template-columns:1fr 1fr;margin-bottom:14px;}.article-card.featured-card .article-card-image{min-height:240px;}.article-card.featured-card .article-card-body{padding:22px;}.article-card.featured-card .article-card-title{font-size:22px;-webkit-line-clamp:3;}.article-card.featured-card .article-card-excerpt{-webkit-line-clamp:3;font-size:14px;}

/* ARCHIVE */
.archive-section{padding:0 22px;margin-bottom:14px;}.archive-filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px;padding:0 22px;justify-content:center;}
.filter-btn{padding:5px 12px;border-radius:6px;font-size:12px;font-weight:700;color:var(--muted);background:var(--card);cursor:pointer;transition:all 0.2s;border:1px solid var(--card-border);text-decoration:none;}.filter-btn:hover{border-color:var(--whitesox-primary);color:var(--whitesox-primary);}[data-theme="dark"] .filter-btn:hover{border-color:var(--whitesox-accent);color:var(--whitesox-accent);}.filter-btn.active{background:var(--whitesox-primary);color:#fff;border-color:var(--whitesox-primary);}
.archive-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 22px;}.archive-load-more{text-align:center;padding:16px;}
.load-more-btn{background:transparent;border:2px dashed var(--card-border);color:var(--muted);padding:12px 32px;border-radius:10px;font:700 14px 'Manrope',sans-serif;cursor:pointer;transition:all 0.2s;}.load-more-btn:hover{border-color:var(--whitesox-accent);color:var(--whitesox-primary);background:rgba(196,206,212,0.03);}[data-theme="dark"] .load-more-btn:hover{color:var(--whitesox-accent);}.load-more-btn:disabled{opacity:0.4;cursor:default;}

/* PROMO BANNERS — White Sox charcoal colorways */
.promo-banner{max-width:960px;margin:0 auto 14px;border-radius:12px;padding:18px 22px;display:flex;align-items:flex-start;gap:14px;position:relative;overflow:hidden;width:calc(100% - 44px);}
.promo-newsletter{background:linear-gradient(135deg,#27251f 0%,#000 100%);color:#fff;border:1px solid rgba(196,206,212,0.25);border-left:3px solid #c4ced4;}
.promo-newsletter .promo-title{font-size:20px;}.promo-newsletter .promo-desc{font-size:12px;}
.promo-write{background:linear-gradient(135deg,#27251f 0%,#000 100%);color:#fff;border:1px solid rgba(255,255,255,0.1);}
.promo-write .promo-title{font-size:20px;}.promo-write .promo-desc{font-size:12px;}
.promo-contact{border:2px solid var(--whitesox-accent);background:rgba(39,37,31,0.05);}[data-theme="dark"] .promo-contact{border-color:rgba(196,206,212,0.3);background:rgba(39,37,31,0.15);}
.promo-contact .promo-title{font-size:20px;}.promo-contact .promo-desc{font-size:12px;}
.promo-forum{background:linear-gradient(135deg,#1a1a1a 0%,#060606 100%);color:#fff;border:1px solid rgba(196,206,212,0.15);}
.promo-forum .promo-title{font-size:20px;}.promo-forum .promo-desc{font-size:12px;}
.promo-icon{font-size:26px;flex-shrink:0;}.promo-body{flex:1;}.promo-title{font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:0.5px;margin-bottom:2px;}.promo-desc{font-size:10px;opacity:0.8;line-height:1.5;}
.promo-input-row{display:flex;gap:5px;margin-top:7px;}.promo-input{flex:1;padding:7px 10px;border-radius:6px;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.04);color:#fff;font:400 10px 'Manrope',sans-serif;}.promo-input::placeholder{color:rgba(255,255,255,0.25);}.promo-input:focus{outline:none;border-color:var(--whitesox-accent);}
.promo-btn{padding:7px 12px;border-radius:6px;border:none;font:700 10px 'Manrope',sans-serif;cursor:pointer;transition:all 0.2s;white-space:nowrap;}
.promo-btn-red{background:var(--red);color:#fff;}.promo-btn-red:hover{background:#e04444;}
.promo-btn-charcoal{background:#27251f;color:#fff;border:1px solid rgba(255,255,255,0.15);}.promo-btn-charcoal:hover{background:#3a3830;}
.promo-btn-silver{background:#c4ced4;color:#27251f;font-weight:800;}.promo-btn-silver:hover{background:#d8dfe3;}
.promo-btn-red-charcoal{background:var(--red);color:#fff;border:2px solid #27251f;}.promo-btn-red-charcoal:hover{background:#e04444;}

/* PROMO SOCIAL BUTTONS */
.promo-social-btns{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap;}
.promo-btn-x{background:#000;color:#fff;border:1px solid rgba(255,255,255,0.15);display:inline-flex;align-items:center;gap:5px;}.promo-btn-x:hover{background:#222;transform:translateY(-1px);}
.promo-btn-fb{background:#1877f2;color:#fff;border:none;display:inline-flex;align-items:center;gap:5px;}.promo-btn-fb:hover{background:#1668d6;transform:translateY(-1px);}
.promo-btn-ig{background:linear-gradient(45deg,#f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%);color:#fff;border:none;display:inline-flex;align-items:center;gap:5px;}.promo-btn-ig:hover{opacity:0.88;transform:translateY(-1px);}

/* FOOTER */
.site-footer{margin-top:20px;padding:30px 22px 20px;border-top:1px solid var(--card-border);}[data-theme="light"] .site-footer{background:#fafaf8;}[data-theme="dark"] .site-footer{background:#0d0d14;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:22px;max-width:900px;margin:0 auto;}.footer-tagline{font-size:10px;color:var(--muted);line-height:1.4;}.footer-col-title{font-size:8px;font-weight:800;letter-spacing:0.1em;margin-bottom:6px;text-transform:uppercase;}
.footer-link{display:block;font-size:10px;color:var(--muted);padding:2px 0;text-decoration:none;transition:color 0.2s;}.footer-link:hover{color:var(--whitesox-accent);}[data-theme="light"] .footer-link:hover{color:var(--whitesox-primary);}
.footer-bottom{margin-top:22px;padding-top:12px;border-top:1px solid var(--card-border);text-align:center;}.footer-copy{font-size:9px;color:var(--muted);}.footer-disclaimer{font-size:8px;color:var(--muted);opacity:0.5;margin-top:3px;line-height:1.3;max-width:600px;margin-left:auto;margin-right:auto;}

@keyframes fadeInUp{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}.animate-in{animation:fadeInUp 0.35s ease-out backwards;}
@keyframes newsletterPulse{0%{box-shadow:0 0 0 6px rgba(196,206,212,0.7),0 12px 40px rgba(196,206,212,0.35);}60%{box-shadow:0 0 0 3px rgba(196,206,212,0.4),0 8px 24px rgba(196,206,212,0.2);}100%{box-shadow:var(--card-shadow);}}
#newsletter:target{animation:newsletterPulse 2.2s ease-out forwards;}

/* RESPONSIVE */
@media(max-width:1024px){.sidebar{display:none;}.main-content{margin-left:0;max-width:100vw;overflow-x:clip;}.mobile-header{display:flex;}.topbar-desk{display:none;}.promo-rail{display:none;}.hero-section{padding:8px;max-width:100%;}.hero-card{grid-template-columns:1fr;min-height:auto;}.hero-image-wrap{height:200px;position:relative;}.hero-body{padding:16px;}.hero-title{font-size:24px;}.hero-recent{grid-template-columns:1fr;gap:8px;}.schedule-strip{padding:0 8px;}.schedule-strip-inner{grid-template-columns:1fr 1fr;gap:8px;}.zone-widgets-row{grid-template-columns:1fr;padding:0 8px;width:calc(100% - 16px);}.category-slot{padding:0 8px;}.category-grid{grid-template-columns:1fr;}.archive-section{padding:0 8px;}.archive-grid{grid-template-columns:1fr;padding:0;}.archive-filters{padding:0;justify-content:center;}.promo-banner{margin-left:auto;margin-right:auto;margin-bottom:10px;padding:14px;flex-direction:column;align-items:center;text-align:center;gap:6px;max-width:calc(100% - 16px);width:calc(100% - 16px);}.promo-input-row{flex-direction:column;width:100%;}.promo-social-btns{flex-direction:column;align-items:center;width:100%;}.promo-social-btns .promo-btn{width:100%;justify-content:center;}.footer-grid{grid-template-columns:1fr 1fr;gap:14px;text-align:center;}.footer-grid > div{display:flex;flex-direction:column;align-items:center;}.site-footer{padding:18px 8px 14px;max-width:100%;}.article-card.featured-card{grid-template-columns:1fr;}.article-card.featured-card .article-card-image{height:180px;min-height:180px;}.zone-title-bar{padding:0 8px;position:fixed;left:0;right:0;top:0;z-index:70;transition:transform 0.3s ease;}.zone-title-bar.header-hidden{transform:translateY(-100%);}.zone-title-name{font-size:36px;}.cat-section-header{padding:0 8px;}.cat-section-name{font-size:38px;}.zone-title-inner{border-bottom:3px solid var(--whitesox-accent);}.cat-section-header-inner{border-bottom:3px solid var(--whitesox-accent);}}
@media(min-width:500px) and (max-width:1024px){.category-grid{grid-template-columns:1fr 1fr;}.archive-grid{grid-template-columns:1fr 1fr;}.article-card{grid-template-columns:150px 1fr;}}
@media(max-width:499px){body{overflow-x:clip;}.main-content{width:100vw;}.article-card{grid-template-columns:130px 1fr;}.article-card-image{min-height:120px;}.hero-recent-card{grid-template-columns:120px 1fr;}.schedule-strip-inner{grid-template-columns:1fr;}.footer-grid{grid-template-columns:1fr;text-align:center;}.footer-grid > div{display:flex;flex-direction:column;align-items:center;}.mobile-actions{gap:4px;}.hero-section{padding:4px;}.archive-filters{gap:4px;justify-content:center;}.filter-btn{padding:4px 8px;font-size:10px;}.standings-header,.standings-row{grid-template-columns:1fr 45px 35px 38px 35px 30px;font-size:9px;}}

@media(min-width:1025px){
  .sidebar .nav-section-label{font-size:10px;}
  .sidebar .sidebar-nav-item{font-size:13px;}
  .sidebar .sidebar-nav-item .nav-icon{font-size:15px;}
  .sidebar .sidebar-nav-item .nav-chevron{font-size:9px;}
  .sidebar .sidebar-nav-item .nav-badge{font-size:9px;}
  .sidebar .subnav a{font-size:11px;}
  .sidebar .todays-games-title{font-size:15px;}
  .sidebar .game-row{font-size:11px;}
  .sidebar .game-status{font-size:10px;}
}

/* ============================================================
   PROMO THEME VARIANTS — White Sox Jersey Colorways
   Rail cards: 2 per section. Horizontal banners: 1 per section.
   ============================================================ */

/* SHARED: rail-emoji (missing from base White Sox styles) */
.rail-emoji{font-size:1.6em;display:block;text-align:center;margin-bottom:6px;line-height:1;}

/* ---------------------------------------------------------------
   HOME WHITE PINSTRIPE (hero section & all-articles)
   Palette: white #f8f8f8 fabric + black pinstripes + charcoal text box w/ silver border
--------------------------------------------------------------- */
.rail-sox-pinstripe-forum,.rail-sox-pinstripe-write{background-color:#f8f8f8;background-image:linear-gradient(to right,transparent 0px,transparent 21px,rgba(0,0,0,0.45) 21px,rgba(0,0,0,0.45) 22px);background-size:22px 100%;background-position:center top;color:#27251f;border:1px solid rgba(0,0,0,0.15);border-top:3px solid #c4ced4;}
.rail-sox-pinstripe-forum .rail-text-box,.rail-sox-pinstripe-write .rail-text-box{background:#27251f;border:2px solid #c4ced4;border-radius:6px;padding:6px 10px 8px;margin-bottom:12px;}
.rail-sox-pinstripe-forum .rail-title,.rail-sox-pinstripe-write .rail-title{color:#c4ced4;display:block;margin-bottom:4px;font-size:20px;}
.rail-sox-pinstripe-forum .rail-desc,.rail-sox-pinstripe-write .rail-desc{color:rgba(255,255,255,0.85);display:block;opacity:1;font-size:12px;}
.rail-sox-pinstripe-forum .rail-btn-silver{background:#c4ced4;color:#27251f;border:1px solid rgba(255,255,255,0.2);}
.rail-sox-pinstripe-forum .rail-btn-silver:hover{background:#d8dfe3;transform:translateY(-1px);}
.rail-sox-pinstripe-write .rail-btn-charcoal{background:#c4ced4;color:#27251f;border:1px solid rgba(255,255,255,0.2);}
.rail-sox-pinstripe-write .rail-btn-charcoal:hover{background:#d8dfe3;transform:translateY(-1px);}

/* HORIZONTAL BANNER: White Pinstripe newsletter (hero section & bottom) */
.promo-sox-pinstripe-newsletter{background-color:#f8f8f8;background-image:linear-gradient(to right,transparent 0px,transparent 21px,rgba(0,0,0,0.45) 21px,rgba(0,0,0,0.45) 22px);background-size:22px 100%;background-position:center top;color:#27251f;border:1px solid rgba(0,0,0,0.1);border-left:4px solid #c4ced4;}
.promo-sox-pinstripe-newsletter .promo-text-box{background:#27251f;border:2px solid #c4ced4;border-radius:6px;padding:6px 10px 8px;margin-bottom:10px;display:table;}
.promo-sox-pinstripe-newsletter .promo-title{color:#c4ced4;display:block;font-size:20px;}
.promo-sox-pinstripe-newsletter .promo-desc{color:rgba(255,255,255,0.85);display:block;opacity:1;font-size:12px;}
.promo-sox-pinstripe-newsletter .promo-input{background:rgba(255,255,255,0.5);border-color:rgba(39,37,31,0.25);color:#27251f;}
.promo-sox-pinstripe-newsletter .promo-input::placeholder{color:rgba(39,37,31,0.45);}
.promo-sox-pinstripe-newsletter .promo-btn-silver{background:#c4ced4;color:#27251f;font-weight:800;border:none;}
.promo-sox-pinstripe-newsletter .promo-btn-silver:hover{background:#d8dfe3;}

/* ---------------------------------------------------------------
   GREY AWAY JERSEY (Game Recaps & Roster Moves sections)
   Palette: road grey #bcc3cc fabric, black "Chicago" lettering
--------------------------------------------------------------- */
.rail-sox-grey-social,.rail-sox-grey-write{background:linear-gradient(180deg,#bcc3cc 0%,#8e9bab 100%);color:#27251f;border:1px solid rgba(39,37,31,0.18);border-top:3px solid #27251f;}
.rail-sox-grey-social .rail-title,.rail-sox-grey-write .rail-title{color:#27251f;opacity:1;text-shadow:none;font-size:20px;}
.rail-sox-grey-social .rail-desc,.rail-sox-grey-write .rail-desc{color:rgba(39,37,31,0.72);opacity:1;font-size:12px;}
.rail-sox-grey-social .rail-social-links a{color:rgba(39,37,31,0.5);}
.rail-sox-grey-social .rail-social-links a:hover{color:#27251f;}
.rail-sox-grey-write .rail-btn-charcoal{background:#27251f;color:#fff;border:1px solid rgba(255,255,255,0.15);}
.rail-sox-grey-write .rail-btn-charcoal:hover{background:#3a3830;transform:translateY(-1px);}

/* HORIZONTAL BANNER: Grey away jersey (after Game Recaps & before archive/Roster Moves) */
.promo-sox-grey-write{background:linear-gradient(135deg,#bcc3cc 0%,#8e9bab 100%);color:#27251f;border:1px solid rgba(39,37,31,0.18);border-left:4px solid #27251f;}
.promo-sox-grey-write .promo-title{color:#27251f;font-size:20px;}
.promo-sox-grey-write .promo-desc{color:rgba(39,37,31,0.72);opacity:1;font-size:12px;}
.promo-sox-grey-write .promo-btn-charcoal{background:#27251f;color:#fff;border:1px solid rgba(255,255,255,0.15);}
.promo-sox-grey-write .promo-btn-charcoal:hover{background:#3a3830;}
.promo-sox-grey-write .promo-input{background:rgba(39,37,31,0.1);border:1px solid rgba(39,37,31,0.4);color:#27251f;}
.promo-sox-grey-write .promo-input::placeholder{color:rgba(39,37,31,0.45);}
.promo-sox-grey-write .promo-input:focus{outline:none;border-color:#27251f;}

/* ---------------------------------------------------------------
   BLACK ALTERNATE JERSEY (Analysis section)
   Palette: solid black fabric + white/silver SOX logo + silver trim
--------------------------------------------------------------- */
.rail-sox-black-newsletter,.rail-sox-black-forum{background:linear-gradient(180deg,#1a1a1a 0%,#000 100%);color:#fff;border:1px solid rgba(196,206,212,0.2);border-top:3px solid #c4ced4;}
.rail-sox-black-newsletter .rail-title,.rail-sox-black-newsletter .rail-desc,.rail-sox-black-forum .rail-title,.rail-sox-black-forum .rail-desc{color:#fff;opacity:1;}
.rail-sox-black-newsletter .rail-title,.rail-sox-black-forum .rail-title{font-size:20px;}
.rail-sox-black-newsletter .rail-desc,.rail-sox-black-forum .rail-desc{font-size:12px;}
.rail-sox-black-newsletter .rail-btn-silver{background:rgba(196,206,212,0.75);color:#000;border:1px solid rgba(196,206,212,0.4);}
.rail-sox-black-newsletter .rail-btn-silver:hover{background:#c4ced4;transform:translateY(-1px);}
.rail-sox-black-forum .rail-btn-silver{background:rgba(196,206,212,0.7);color:#000;border:1px solid rgba(196,206,212,0.4);}
.rail-sox-black-forum .rail-btn-silver:hover{background:#c4ced4;transform:translateY(-1px);}

/* HORIZONTAL BANNER: Black alternate jersey (after Analysis) */
.promo-sox-black-forum{background:linear-gradient(135deg,#1a1a1a 0%,#000 100%);color:#fff;border:1px solid rgba(196,206,212,0.2);border-left:4px solid #c4ced4;}
.promo-sox-black-forum .promo-title{color:#fff;font-size:20px;}
.promo-sox-black-forum .promo-desc{color:rgba(255,255,255,0.85);opacity:1;font-size:12px;}
.promo-sox-black-forum .promo-input{background:rgba(196,206,212,0.1);border-color:rgba(196,206,212,0.3);color:#fff;}
.promo-sox-black-forum .promo-input::placeholder{color:rgba(255,255,255,0.35);}
.promo-sox-black-forum .promo-btn-silver{background:#c4ced4;color:#27251f;border:none;}
.promo-sox-black-forum .promo-btn-silver:hover{background:#d8dfe3;}

/* ---------------------------------------------------------------
   SOUTHSIDE BLACK PINSTRIPE (Rebuild Watch section)
   Palette: dark charcoal #141414 fabric + subtle grey pinstripes + silver trim
   Mirrors the City Connect / Southside alternate jersey
--------------------------------------------------------------- */
.rail-sox-southside-newsletter,.rail-sox-southside-write{background-color:#141414;background-image:linear-gradient(to right,transparent 0px,transparent 21px,rgba(180,180,180,0.16) 21px,rgba(180,180,180,0.16) 22px);background-size:22px 100%;background-position:center top;color:#fff;border:1px solid rgba(196,206,212,0.15);border-top:3px solid #c4ced4;}
.rail-sox-southside-newsletter .rail-text-box,.rail-sox-southside-write .rail-text-box{background:rgba(0,0,0,0.55);border:2px solid #c4ced4;border-radius:6px;padding:6px 10px 8px;margin-bottom:12px;}
.rail-sox-southside-newsletter .rail-title,.rail-sox-southside-write .rail-title{color:#c4ced4;display:block;margin-bottom:4px;font-size:20px;}
.rail-sox-southside-newsletter .rail-desc,.rail-sox-southside-write .rail-desc{color:rgba(255,255,255,0.85);display:block;opacity:1;font-size:12px;}
.rail-sox-southside-newsletter .rail-btn-charcoal{background:#c4ced4;color:#27251f;border:1px solid rgba(255,255,255,0.15);}
.rail-sox-southside-newsletter .rail-btn-charcoal:hover{background:#d8dfe3;transform:translateY(-1px);}
.rail-sox-southside-write .rail-btn-charcoal{background:#c4ced4;color:#27251f;border:1px solid rgba(255,255,255,0.15);}
.rail-sox-southside-write .rail-btn-charcoal:hover{background:#d8dfe3;transform:translateY(-1px);}

/* HORIZONTAL BANNER: Southside black pinstripe (after Rebuild Watch) */
.promo-sox-southside-contact{background-color:#141414;background-image:linear-gradient(to right,transparent 0px,transparent 21px,rgba(180,180,180,0.16) 21px,rgba(180,180,180,0.16) 22px);background-size:22px 100%;background-position:center top;color:#fff;border:1px solid rgba(196,206,212,0.15);border-left:4px solid #c4ced4;}
.promo-sox-southside-contact .promo-title{color:#c4ced4;font-size:20px;}
.promo-sox-southside-contact .promo-desc{color:rgba(255,255,255,0.8);opacity:1;font-size:12px;}
.promo-sox-southside-contact .promo-btn-silver{background:#c4ced4;color:#27251f;font-weight:800;border:none;}
.promo-sox-southside-contact .promo-btn-silver:hover{background:#d8dfe3;}

/* ---- MLB API: Streak colors ---- */
.streak-win{color:#4ade80;font-weight:800;}
.streak-loss{color:#f87171;font-weight:800;}
[data-theme="light"] .streak-win{color:#16a34a;}
[data-theme="light"] .streak-loss{color:#dc2626;}

/* ---- Calendar game card: home/away border variants ---- */
.calendar-game-card.cal-card-home{border-left-color:#f0f0f0;}
.calendar-game-card.cal-card-away{border-left-color:var(--whitesox-accent);}
[data-theme="light"] .calendar-game-card.cal-card-home{border-left-color:#555;}
[data-theme="light"] .calendar-game-card.cal-card-away{border-left-color:var(--whitesox-primary);}

/* ---- Calendar live + score display ---- */
.cal-game-card-live{font-size:11px;font-weight:800;letter-spacing:0.06em;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-bottom:3px;}
[data-theme="light"] .cal-game-card-live{color:rgba(0,0,0,0.6);}
.cal-game-card-score{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:0.5px;line-height:1.1;color:#fff;margin:2px 0 4px;}
[data-theme="light"] .cal-game-card-score{color:#111;}

/* ---- Schedule strip: pitcher 3-column layout ---- */
.schedule-pitcher-line{display:grid;grid-template-columns:1fr auto 1fr;gap:0 4px;align-items:start;margin-top:6px;text-align:center;line-height:1.4;}
.pitcher-sox{text-align:left;font-size:13px;color:var(--muted);font-weight:600;line-height:1.4;}
.pitcher-opp{text-align:right;font-size:13px;color:var(--muted);font-weight:600;line-height:1.4;}
.pitcher-stat{display:block;font-weight:400;opacity:0.75;font-size:12px;}
.pitcher-vs{text-align:center;font-size:10px;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;opacity:0.4;padding-top:1px;}
/* Pitcher text contrast — dark mode */
[data-theme="dark"] .pitcher-sox,[data-theme="dark"] .pitcher-opp{color:#ffffff;}
[data-theme="dark"] .pitcher-stat{color:rgba(255,255,255,0.8);opacity:1;}
[data-theme="dark"] .pitcher-vs{color:rgba(255,255,255,0.45);opacity:1;}
/* Pitcher text contrast — light mode */
[data-theme="light"] .pitcher-sox,[data-theme="light"] .pitcher-opp{color:#1a2a4a;}
[data-theme="light"] .pitcher-stat{color:#2a3f5a;opacity:1;}
[data-theme="light"] .pitcher-vs{color:#8a9baf;opacity:1;}
/* Calendar game card detail (time) contrast */
[data-theme="dark"] .cal-game-card-details{color:rgba(255,255,255,0.82);}
[data-theme="light"] .cal-game-card-details{color:rgba(0,0,0,0.72);}
