:root{
  --primary:#085cac;
  --accent:#ffffff;
  --danger:#c81b1f;
  --text:#101828;
  --bg:#f7f7f9;
  --grid-row-green:#e6f5e9;
  --grid-row-blue:#e6f0ff;
  --grid-mark-home:#c81b1f;
  --grid-mark-away:#5e3fa9;
  --grid-bye:#0b1d6a;
  --marker-home-bg:#fee2e2;
  --marker-home-text:#7f1d1d;
  --marker-away-bg:#ede9fe;
  --marker-away-text:#4c1d95;
  --marker-bye-bg:#dbeafe;
  --marker-bye-text:#1d4ed8;
  --marker-neutral-bg:#f1f5f9;
  --marker-neutral-text:#1f2937;
  --radius:16px;
  --pad:16px;
}
*{box-sizing:border-box}
.sr-only{position:absolute;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;width:1px;overflow:hidden;white-space:nowrap;}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);}
.app-body{background:var(--bg);}
.app-container{min-height:100vh;display:flex;flex-direction:column;}
.app-header{display:flex;flex-direction:column;gap:12px;align-items:stretch;padding:18px 32px;background:#fff;border-bottom:1px solid #e6e9f2;position:sticky;top:0;z-index:50;box-shadow:0 8px 24px rgba(16,24,40,0.04);}
.app-header__bar{display:flex;align-items:center;justify-content:space-between;gap:24px;}
.app-logo{font-family:'Orbitron',system-ui;font-style:italic;font-weight:700;color:var(--primary);text-decoration:none;font-size:20px;letter-spacing:1px;}
.app-header__meta{display:flex;align-items:center;gap:16px;}
.settings-menu{position:relative;display:inline-flex;}
.settings-menu summary::-webkit-details-marker{display:none;}
.settings-menu__trigger{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:999px;border:1px solid rgba(8,92,172,0.2);background:#fff;color:#1d2939;font-weight:600;cursor:pointer;transition:all .2s ease;list-style:none;}
.settings-menu__trigger::after{content:'▾';font-size:12px;color:#475467;}
.settings-menu__trigger:focus,.settings-menu__trigger:hover{border-color:var(--primary);color:var(--primary);outline:none;}
.settings-menu__panel{position:absolute;right:0;top:calc(100% + 12px);background:#fff;border-radius:16px;box-shadow:0 18px 40px rgba(15,23,42,0.12);padding:18px;display:none;min-width:220px;z-index:100;flex-direction:column;gap:18px;border:1px solid #e5e7eb;}
.settings-menu[open] .settings-menu__panel{display:flex;}
.settings-menu__section{display:flex;flex-direction:column;gap:10px;}
.settings-menu__title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#475467;}
.settings-menu__link{display:flex;align-items:center;gap:8px;color:#1d2939;font-size:14px;font-weight:600;text-decoration:none;padding:8px 10px;border-radius:10px;transition:background .2s ease,color .2s ease;}
.settings-menu__link:hover{background:rgba(8,92,172,0.08);color:var(--primary);}
.settings-menu__action{margin:0;}
.settings-menu__action button{width:100%;background:none;border:none;padding:0;text-align:left;color:#1d2939;font-size:14px;font-weight:600;cursor:pointer;}
.settings-menu__action button:hover{color:var(--primary);}
.app-nav{display:flex;align-items:center;gap:20px;}
.app-nav__link{color:#475467;font-weight:600;text-decoration:none;font-size:15px;transition:color .2s ease;}
.app-nav__link:hover{color:var(--primary);}
.app-user{display:flex;align-items:center;gap:16px;}
.app-user__meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;}
.app-user__name{font-weight:600;font-size:15px;color:#1d2939;}
.app-user__email{font-size:13px;color:#667085;}
.app-logout-form{margin:0;}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border-radius:999px;font-weight:600;border:1px solid transparent;font-size:14px;line-height:1.2;cursor:pointer;transition:all .2s ease;}
.btn--primary{background:var(--primary);color:#fff;border-color:var(--primary);}
.btn--primary:hover{box-shadow:0 10px 20px rgba(8,92,172,0.18);}
.btn--danger{background:var(--danger);border-color:var(--danger);color:#fff;}
.btn--danger:hover{box-shadow:0 10px 20px rgba(200,27,31,0.18);}
.btn--ghost{background:transparent;color:var(--primary);border-color:rgba(8,92,172,0.2);}
.btn--ghost:hover{border-color:var(--primary);color:var(--primary);background:rgba(8,92,172,0.06);}
.form-warning{margin:12px 0 0;font-size:0.92rem;color:var(--danger);font-weight:500;}
.upload-dropzone{position:relative;border:2px dashed rgba(8,92,172,0.4);border-radius:20px;padding:28px 24px;text-align:center;background:#f8fafc;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease;cursor:pointer;display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center;}
.upload-dropzone__title{margin:0;font-weight:600;font-size:1.05rem;color:#0f172a;}
.upload-dropzone__hint{margin:0;font-size:0.9rem;color:#475467;}
.upload-dropzone__input{position:absolute;inset:0;opacity:0;cursor:pointer;}
.upload-dropzone--hover{background:#eef2ff;border-color:var(--primary);box-shadow:0 12px 30px rgba(8,92,172,0.12);}
.upload-dropzone--selected{background:#fff;border-style:solid;border-color:var(--primary);}
.app-main{flex:1;padding:32px;max-width:1200px;margin:0 auto;width:100%;}
.flash-stack{display:flex;flex-direction:column;gap:12px;margin-bottom:24px;}
.flash{padding:14px 18px;border-radius:12px;font-weight:500;border:1px solid transparent;box-shadow:0 6px 16px rgba(15,23,42,0.08);background:#fff;color:#1d2939;}
.flash--success{border-color:#34d399;background:#f0fdf4;color:#065f46;}
.flash--error{border-color:#f87171;background:#fef2f2;color:#7f1d1d;}
.flash--warning{border-color:#fbbf24;background:#fffbeb;color:#78350f;}
.wizard-note{background:#fef3c7;border:1px solid #facc15;color:#92400e;border-radius:14px;padding:14px 16px;font-size:.95rem;margin:0 0 18px;}
.build-overlay__eta{font-weight:600;color:#475467;}
.league-banner{margin:16px 32px 0;background:#fff;border:1px solid #d0d5dd;border-radius:16px;padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:24px;box-shadow:0 10px 24px rgba(16,24,40,0.06);}
.league-banner__label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#667085;font-weight:600;}
.league-banner__name{font-size:20px;font-weight:700;color:#1d2939;margin-top:4px;}
.league-banner__name a{color:inherit;text-decoration:none;display:inline-flex;align-items:center;gap:6px;}
.league-banner__name a:hover{text-decoration:underline;}
.league-banner__actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.league-banner__code{font-size:13px;color:#475467;padding:6px 14px;border-radius:999px;background:#eef2ff;font-weight:600;display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;transition:all .2s ease;}
.league-banner__code:hover{background:#e0e7ff;color:#1d4ed8;}
.active-build-tabs{width:100%;padding-top:4px;}
.active-build-tabs__list{display:flex;align-items:stretch;gap:12px;width:100%;overflow-x:auto;padding-bottom:4px;margin:0;scrollbar-width:thin;}
.active-build-tabs__list::-webkit-scrollbar{height:6px;}
.active-build-tabs__list::-webkit-scrollbar-track{background:transparent;}
.active-build-tabs__list::-webkit-scrollbar-thumb{background:rgba(15,23,42,0.18);border-radius:999px;}
.active-build-tab{flex:1 1 240px;min-width:0;background:#fff;border:1px solid #d0d5dd;border-radius:14px;padding:12px 16px;box-shadow:0 12px 24px rgba(16,24,40,0.06);display:flex;flex-direction:column;gap:8px;transition:transform .2s ease,box-shadow .2s ease;position:relative;}
.active-build-tab--solo{flex:1 1 100%;}
.active-build-tabs--multi .active-build-tab{flex:1 1 220px;}
.active-build-tab--compact .active-build-tab__title{font-size:13px;}
.active-build-tab--compact .active-build-tab__status-line{font-size:12px;}
.active-build-tab__dot{color:#c4c7d0;font-weight:600;}
.active-build-tab__dot[hidden]{display:none;}
.active-build-tab__eta{font-size:12px;font-weight:500;color:#475467;white-space:nowrap;}
.active-build-tab__header{display:flex;align-items:center;justify-content:space-between;gap:12px;position:relative;}
.active-build-tab__title{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:#0f172a;min-width:0;}
.active-build-tab__league,.active-build-tab__sport{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.active-build-tab__separator{color:#c4c7d0;font-weight:600;}
.active-build-tab__status-line{display:flex;align-items:center;gap:10px;font-size:13px;color:#475467;flex-wrap:wrap;}
.active-build-tab__status{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#085cac;}
.active-build-tab[data-status="queued"] .active-build-tab__status{color:#b54708;}
.active-build-tab[data-status="failed"] .active-build-tab__status{color:#b42318;}
.active-build-tab[data-status="cancelled"] .active-build-tab__status{color:#475467;}
.active-build-tab[data-status="completed"] .active-build-tab__status{color:#027a48;}
.active-build-tab__meta{font-weight:500;}
.active-build-tab__bar{position:relative;width:100%;height:6px;border-radius:999px;background:rgba(8,92,172,0.12);overflow:hidden;}
.active-build-tab__bar-fill{position:absolute;inset:0;background:var(--primary);width:0%;transition:width .3s ease;}
.active-build-tab__message{font-size:12px;color:#b42318;min-height:14px;}
.active-build-tab--has-message{border-color:#f79009;}
.active-build-tab__cancel{background:rgba(8,92,172,0.12);border:none;border-radius:999px;padding:4px 10px;font-weight:700;font-size:12px;color:#0f172a;cursor:pointer;transition:background .2s ease,color .2s ease;display:inline-flex;align-items:center;justify-content:center;}
.active-build-tab__cancel:hover:not([aria-disabled="true"]){background:rgba(8,92,172,0.2);color:#052c65;}
.active-build-tab__cancel[aria-disabled="true"]{opacity:.5;cursor:not-allowed;}
.active-build-tab__cancel span[aria-hidden="true"]{font-size:14px;line-height:1;}
.active-build-tab__confirm{position:absolute;top:calc(100% + 10px);right:0;width:min(320px,calc(100vw - 40px));background:#fff;border:1px solid #e4e7ec;border-radius:14px;box-shadow:0 18px 38px rgba(15,23,42,0.18);padding:16px;display:flex;flex-direction:column;gap:12px;z-index:20;}
.active-build-tab__confirm-message{font-size:13px;color:#344054;font-weight:600;line-height:1.5;}
.active-build-tab__confirm-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px;}
.active-build-tab__confirm-delete{background:#c81b1f;color:#fff;border:none;border-radius:999px;padding:8px 16px;font-size:13px;font-weight:700;cursor:pointer;transition:background .2s ease,box-shadow .2s ease;}
.active-build-tab__confirm-delete:hover{background:#a11215;box-shadow:0 10px 20px rgba(200,27,31,0.25);}
.active-build-tab__confirm-cancel{background:transparent;border:none;font-size:13px;font-weight:600;color:#475467;cursor:pointer;padding:8px 0;}
.active-build-tab__confirm-cancel:hover{color:#0f172a;text-decoration:underline;}
@media (max-width:768px){
  .app-header{padding:16px 20px;gap:10px;}
  .active-build-tabs__list{gap:10px;}
  .active-build-tab{padding:12px 14px;}
  .active-build-tab__title{font-size:13px;}
  .active-build-tab__status-line{font-size:12px;}
}
.app-main .card-grid{display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));}
.auth-wrapper{display:flex;align-items:center;justify-content:center;padding:48px 0;}
.auth-card{width:min(520px,100%);background:#fff;border-radius:24px;padding:40px;border:1px solid #e5eaf2;box-shadow:0 24px 60px rgba(8,92,172,0.08);display:flex;flex-direction:column;gap:24px;}
.auth-title{margin:0;font-size:28px;font-weight:700;color:#0f172a;}
.auth-subtitle{margin:0;font-size:15px;color:#475467;}
.auth-form{display:flex;flex-direction:column;gap:18px;}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;}
.form-field{display:flex;flex-direction:column;gap:8px;}
.form-label{font-size:13px;font-weight:600;color:#344054;}
.form-input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid #d0d5dd;font-size:15px;transition:border-color .2s ease,box-shadow .2s ease;background:#fff;}
.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(8,92,172,.12);}
.form-error{font-size:12px;color:#b42318;}
.form-actions{display:flex;align-items:center;justify-content:space-between;font-size:13px;color:#475467;}
.form-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:#475467;cursor:pointer;}
.form-checkbox input{width:16px;height:16px;}
.form-link{color:var(--primary);text-decoration:none;font-weight:600;}
.form-link:hover{text-decoration:underline;}
.auth-submit{width:100%;margin-top:8px;}
.auth-footer{font-size:13px;color:#475467;margin:0;text-align:center;}
.auth-footer a{color:var(--primary);font-weight:600;}
.checkbox-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-top:6px;}
.page-heading{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px;gap:16px;flex-wrap:wrap;}
.page-title{margin:0;font-size:32px;font-weight:700;color:#0f172a;}
.page-subtitle{margin:6px 0 0;font-size:15px;color:#475467;max-width:560px;}
.leagues-grid{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));}
.card{background:#fff;border-radius:20px;padding:28px;border:1px solid #e4e7ec;box-shadow:0 12px 32px rgba(15,23,42,0.06);display:flex;flex-direction:column;gap:20px;}
.card-title{margin:0;font-size:18px;font-weight:700;color:#101828;}
.card-header{display:flex;flex-direction:column;gap:4px;margin-bottom:4px;}
.card-divider{border:none;height:1px;background:#e4e7ec;margin:8px 0;}
.card-hint{margin:0;color:#475467;font-size:13px;}
.league-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px;}
.league-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border:1px solid #e4e7ec;border-radius:16px;background:#f9fafb;transition:border-color .2s ease,background .2s ease;}
.league-item--active{border-color:var(--primary);background:#eef4ff;}
.league-item__meta h3{margin:0;font-size:16px;font-weight:700;color:#0f172a;}
.league-item__meta p{margin:4px 0 0;font-size:13px;color:#475467;}
.league-item__meta span{font-weight:600;color:#1d4ed8;background:#e0ecff;padding:2px 8px;border-radius:8px;}
.league-switch-form{display:flex;align-items:center;gap:12px;margin:0;}
.badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600;}
.badge--primary{background:#e0ecff;color:#1d4ed8;}
.badge--success{background:#d1fadf;color:#027a48;}
.badge--secondary{background:#f2f4f7;color:#344054;}
.stack-form{display:flex;flex-direction:column;gap:12px;}
.empty-state{padding:18px;border-radius:16px;background:#f8fafc;border:1px dashed #d0d5dd;color:#475467;font-size:14px;}
.dashboard-hero{display:flex;gap:32px;align-items:stretch;flex-wrap:wrap;margin-bottom:32px;}
.dashboard-hero__copy{flex:1 1 380px;background:#fff;border-radius:24px;padding:32px;border:1px solid #e4e7ec;box-shadow:0 18px 45px rgba(8,92,172,0.08);display:flex;flex-direction:column;gap:18px;}
.dashboard-hero__panel{flex:1 1 240px;display:flex;flex-direction:column;gap:18px;}
.eyebrow{text-transform:uppercase;font-weight:600;font-size:12px;letter-spacing:.08em;color:#475467;}
.hero-title{margin:0;font-size:36px;font-weight:800;color:#0f172a;}
.hero-subtitle{margin:0;font-size:16px;color:#475467;line-height:1.6;}
.dashboard-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.stat-card{flex:1;background:#fff;border-radius:20px;padding:24px;border:1px solid #e4e7ec;box-shadow:0 12px 32px rgba(15,23,42,0.07);display:flex;flex-direction:column;gap:6px;}
.stat-label{font-size:13px;text-transform:uppercase;color:#475467;font-weight:600;letter-spacing:.06em;}
.stat-value{font-size:32px;font-weight:800;color:#0f172a;}
.stat-footnote{font-size:12px;color:#667085;}
.schedule-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px;}
.schedule-item{display:flex;align-items:center;justify-content:space-between;padding:18px;border-radius:16px;border:1px solid #e4e7ec;background:#f9fafb;}
.schedule-item h3{margin:0 0 4px;font-size:16px;font-weight:700;color:#0f172a;}
.schedule-item p{margin:0;font-size:13px;color:#475467;}
.sport-grid{list-style:none;margin:0;padding:0;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));}
.sport-card{background:#f9fafb;border:1px solid #e4e7ec;border-radius:18px;padding:20px;display:flex;flex-direction:column;gap:12px;justify-content:space-between;}
.sport-card h3{margin:0;font-size:18px;font-weight:700;color:#0f172a;}
.sport-card p{margin:0;font-size:14px;color:#475467;line-height:1.5;}
.team-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));}
.team-card{background:#f9fafb;border-radius:18px;padding:20px;border:1px solid #e4e7ec;display:flex;flex-direction:column;gap:16px;}
.team-card__head h3{margin:0;font-size:18px;font-weight:700;color:#0f172a;}
.team-card__head p{margin:6px 0 0;font-size:14px;color:#475467;}
.team-card__actions{display:flex;gap:12px;justify-content:flex-end;}
a.btn, button.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border-radius:999px;border:1px solid var(--primary);background:var(--primary);color:#fff;text-decoration:none;font-weight:600}
a.btn.secondary, button.btn.secondary{background:#fff;color:var(--primary)}
button.btn:disabled{background:#9ec5f0;border-color:#9ec5f0}
.container{max-width:1100px;margin:0 auto;padding:24px}
.home-layout{display:grid;grid-template-columns:minmax(260px,320px) minmax(0,1fr);gap:32px;align-items:flex-start;}
.home-leagues{display:flex;flex-direction:column;gap:20px;}
.home-leagues__header h2{margin:0;font-size:20px;font-weight:700;color:#0f172a;}
.home-leagues__header p{margin:4px 0 0;font-size:13px;color:#475467;}
.home-leagues__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px;}
.home-league-card{display:flex;align-items:center;gap:16px;width:100%;padding:14px 16px;border:1px solid #e4e7ec;border-radius:18px;background:#fff;box-shadow:0 10px 24px rgba(15,23,42,0.05);cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease;}
.home-league-card:hover{border-color:var(--primary);box-shadow:0 14px 32px rgba(15,23,42,0.08);transform:translateY(-2px);}
.home-league-card--active{background:linear-gradient(120deg,rgba(8,92,172,0.12),rgba(8,92,172,0.04));border-color:var(--primary);cursor:pointer;box-shadow:0 16px 36px rgba(8,92,172,0.12);}
.home-league-card__media{width:48px;height:48px;border-radius:14px;overflow:hidden;background:rgba(8,92,172,0.12);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--primary);text-transform:uppercase;}
.home-league-card__media img{width:100%;height:100%;object-fit:cover;}
.home-league-card__placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;}
.home-league-card__body{flex:1;display:flex;flex-direction:column;gap:6px;text-align:left;}
.home-league-card__body h3{margin:0;font-size:16px;font-weight:700;color:#0f172a;}
.home-league-card__body p{margin:0;font-size:13px;color:#475467;line-height:1.5;}
.home-league-card__badge{font-size:12px;font-weight:700;color:#0f172a;background:#fff;padding:4px 12px;border-radius:999px;box-shadow:0 6px 14px rgba(15,23,42,0.12);}
.home-league-card__form{margin:0;}
.home-leagues__cta{align-self:flex-start;}
.home-main{display:flex;flex-direction:column;gap:24px;}
.home-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;}
.stat-block{background:#fff;border-radius:18px;padding:20px;border:1px solid #e4e7ec;display:flex;flex-direction:column;gap:4px;box-shadow:0 10px 24px rgba(15,23,42,0.06);}
.stat-block__label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#475467;font-weight:600;}
.stat-block__value{font-size:28px;font-weight:800;color:#0f172a;}
.home-card{gap:16px;}
.home-card__header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.home-card__actions{display:flex;align-items:center;gap:12px;}
.league-home{display:grid;grid-template-columns:minmax(220px,260px) minmax(0,1fr);gap:28px;align-items:flex-start;}
.league-home__nav{display:flex;flex-direction:column;gap:12px;position:sticky;top:120px;}
.league-home__pill{width:100%;padding:12px 20px;border-radius:999px;border:1px solid var(--primary);background:var(--primary);color:#fff;font-weight:600;font-size:14px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;box-shadow:0 10px 24px rgba(8,92,172,0.18);}
.league-home__pill:hover,.league-home__pill:focus{outline:none;transform:translateY(-2px);box-shadow:0 16px 32px rgba(8,92,172,0.22);}
.league-home__pill--ghost{background:#fff;color:var(--primary);box-shadow:0 8px 18px rgba(8,92,172,0.1);}
.league-home__content{display:flex;flex-direction:column;gap:24px;}
.league-home__card{display:flex;flex-direction:column;gap:24px;}
.league-home__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;margin:0;padding:0;}
.league-home__stats div{background:#f9fafb;border:1px solid #e4e7ec;border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:6px;}
.league-home__stats dt{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#475467;font-weight:600;margin:0;}
.league-home__stats dd{margin:0;font-size:24px;font-weight:800;color:#0f172a;}
.league-home__section{display:flex;flex-direction:column;gap:12px;}
.league-home__chips{display:flex;flex-wrap:wrap;gap:10px;margin:0;padding:0;list-style:none;}
.league-home__chips li{padding:6px 14px;border-radius:999px;background:rgba(8,92,172,0.12);color:var(--primary);font-weight:600;font-size:13px;}
.league-home__timeline{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px;}
.league-home__timeline li{display:flex;align-items:center;gap:12px;justify-content:space-between;padding:14px 18px;border-radius:14px;border:1px solid #e4e7ec;background:#fff;box-shadow:0 8px 18px rgba(15,23,42,0.06);flex-wrap:wrap;}
.league-home__timeline-title{font-weight:600;color:#0f172a;}
.league-home__timeline-meta{font-size:13px;color:#667085;}
.league-home__timeline a{color:var(--primary);font-weight:600;text-decoration:none;}
.schedule-list--compact .schedule-item{padding:14px;}
.modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;}
.modal__header h2{margin:0;font-size:20px;font-weight:700;color:#0f172a;}
.modal__close{border:none;background:transparent;font-size:24px;line-height:1;color:#475467;cursor:pointer;padding:0 4px;}
.modal__content{display:flex;flex-direction:column;gap:16px;}
.modal__columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;}
.modal-form{display:flex;flex-direction:column;gap:12px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:16px;padding:20px;}
.modal-form h3{margin:0;font-size:16px;font-weight:700;color:#0f172a;}
.form-hint{font-size:12px;color:#667085;}
.settings-card{display:grid;gap:32px;grid-template-columns:minmax(0,1fr) 280px;align-items:flex-start;}
.settings-form{display:flex;flex-direction:column;gap:24px;}
.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;}
.settings-field{display:flex;flex-direction:column;gap:8px;}
.settings-field--full{grid-column:1/-1;}
.form-input--textarea{min-height:120px;resize:vertical;}
.color-input{display:flex;align-items:center;gap:12px;}
.color-input__swatch{width:36px;height:36px;border-radius:12px;border:1px solid rgba(16,24,40,0.1);}
.color-input__field{flex:1;}
.settings-actions{display:flex;justify-content:flex-end;}
.settings-preview{display:flex;justify-content:center;}
.settings-preview__card{display:flex;gap:16px;align-items:center;padding:20px;border-radius:18px;border:1px solid #e4e7ec;background:#f9fafb;box-shadow:0 12px 30px rgba(15,23,42,0.07);max-width:320px;width:100%;}
.settings-preview__media{width:64px;height:64px;border-radius:18px;overflow:hidden;background:rgba(8,92,172,0.12);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--primary);}
.settings-preview__media img{width:100%;height:100%;object-fit:cover;}
.settings-preview__body{display:flex;flex-direction:column;gap:6px;}
.settings-preview__body h3{margin:0;font-size:18px;font-weight:700;color:#0f172a;}
.settings-preview__body p{margin:0;font-size:13px;color:#475467;}
.settings-preview__badge{align-self:flex-start;color:#fff;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:700;}
.settings-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.card-subtitle{margin:4px 0 0;font-size:13px;color:#475467;}
.settings-card--sports{margin-top:24px;display:flex;flex-direction:column;gap:20px;}
.settings-card--members{margin-top:24px;display:flex;flex-direction:column;gap:16px;}
.settings-list{margin:0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:10px;}
.settings-list li{padding:8px 16px;border-radius:999px;background:rgba(8,92,172,0.1);color:#0f172a;font-weight:600;}
.league-sport-list{display:flex;flex-wrap:wrap;gap:12px;margin:0;padding:0;list-style:none;}
.league-sport-pill{display:inline-flex;align-items:center;gap:10px;padding:8px 18px;border-radius:999px;border:1px solid var(--primary);background:var(--primary);color:#fff;font-weight:600;box-shadow:0 12px 24px rgba(8,92,172,0.18);transition:transform .2s ease,box-shadow .2s ease;}
.league-sport-pill:hover{transform:translateY(-2px);box-shadow:0 18px 36px rgba(8,92,172,0.24);}
.league-sport-pill__label{pointer-events:none;}
.league-sport-pill__remove{width:26px;height:26px;border-radius:999px;border:none;background:rgba(255,255,255,0.25);color:#fff;font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease;}
.league-sport-pill__remove:hover{background:rgba(255,255,255,0.4);}
.sport-pill{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border-radius:999px;border:1px dashed var(--primary);background:#fff;color:var(--primary);font-weight:600;cursor:pointer;transition:all .2s ease;}
.sport-pill--add{border-style:solid;}
.sport-pill:hover{background:rgba(8,92,172,0.08);}
.form-toggle{display:flex;align-items:center;gap:8px;margin-top:10px;color:#475467;font-size:13px;}
.form-toggle__input{width:18px;height:18px;}
.modal__actions{display:flex;justify-content:flex-end;gap:12px;margin-top:18px;}
.copy-toast{position:fixed;bottom:24px;right:24px;background:#101828;color:#fff;padding:12px 18px;border-radius:14px;box-shadow:0 18px 40px rgba(15,23,42,0.18);opacity:0;transform:translateY(10px);transition:opacity .2s ease,transform .2s ease;z-index:120;}
.copy-toast--visible{opacity:1;transform:translateY(0);}
@media(max-width:960px){
  .home-layout{grid-template-columns:1fr;}
  .home-leagues{order:2;}
  .settings-card{grid-template-columns:1fr;}
  .league-home{grid-template-columns:1fr;}
  .league-home__nav{position:static;flex-direction:row;flex-wrap:wrap;gap:10px;}
  .league-home__pill{flex:1 1 calc(50% - 10px);}
}
.grid{display:grid;gap:16px}
.card{background:#fff;border:1px solid #e5e7eb;border-radius:var(--radius);padding:var(--pad)}
.list{list-style:none;padding:0;margin:0}
.item{background:#fff;border:1px solid #e5e7eb;border-radius:var(--radius);padding:12px 14px;display:flex;justify-content:space-between;align-items:center}
.kv{display:grid;grid-template-columns:160px 1fr;gap:8px;align-items:center;margin-bottom:10px}
.constraint-section{margin-bottom:24px}
.constraint-section h3{margin:0;font-size:18px;font-weight:600;color:#101828}
.constraint-settings{list-style:none;margin:16px 0 0;padding:0}
.constraint-settings .kv{margin-bottom:14px}
.constraint-settings .kv:last-child{margin-bottom:0}
.checkbox-row input[type=checkbox]{justify-self:start}
.constraint-note{margin:6px 0 0;font-size:13px;color:#475467}
.input, select{padding:10px 12px;border:1px solid #cbd5e1;border-radius:10px;width:100%}
.table{width:100%;border-collapse:collapse}
.table th,.table td{border-bottom:1px solid #eee;padding:10px;text-align:left}
.marker-cell{background:var(--marker-neutral-bg);transition:background-color .2s ease,color .2s ease}
.marker-cell .marker-select{padding:8px 10px;border:1px solid #cbd5e1;border-radius:10px;width:100%;background:transparent;color:var(--marker-neutral-text);font-weight:600;text-align:center;transition:background-color .2s ease,color .2s ease,border-color .2s ease}
.marker-cell[data-marker="H"]{background:var(--marker-home-bg);color:var(--marker-home-text)}
.marker-cell[data-marker="H"] .marker-select{background:var(--marker-home-bg);color:var(--marker-home-text);border-color:#fca5a5}
.marker-cell[data-marker="A"]{background:var(--marker-away-bg);color:var(--marker-away-text)}
.marker-cell[data-marker="A"] .marker-select{background:var(--marker-away-bg);color:var(--marker-away-text);border-color:#c4b5fd}
.marker-cell[data-marker="B"]{background:var(--marker-bye-bg);color:var(--marker-bye-text)}
.marker-cell[data-marker="B"] .marker-select{background:var(--marker-bye-bg);color:var(--marker-bye-text);border-color:#93c5fd}
.marker-cell[data-marker="I"],.marker-cell[data-marker="N"]{background:var(--marker-neutral-bg);color:var(--marker-neutral-text)}
.marker-cell[data-marker="I"] .marker-select,.marker-cell[data-marker="N"] .marker-select{background:var(--marker-neutral-bg);color:var(--marker-neutral-text);border-color:#cbd5e1}
.progress{height:8px;background:#e5e7eb;border-radius:6px;overflow:hidden}
.progress > div{height:8px;background:var(--primary);width:0%}
.badge{display:inline-block;padding:4px 8px;border-radius:999px;background:#eaf3ff;color:#093b7e;font-size:12px}
.toolbar{display:flex;gap:12px;align-items:center;justify-content:space-between;margin-bottom:12px}
.link{color:var(--primary);text-decoration:none}
footer{padding:24px;color:#6b7280}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.35);display:none;align-items:center;justify-content:center;padding:20px}
.modal.open{display:flex}
.modal .dialog{width:min(720px,95vw);background:#fff;border-radius:16px;padding:20px;border:1px solid #e5e7eb;display:flex;flex-direction:column;gap:16px;max-height:95vh;overflow:hidden}
.dialog__header{display:flex;justify-content:space-between;align-items:center;gap:12px}
.dialog__actions{display:flex;justify-content:flex-end;gap:10px;margin-top:auto}
.dialog--travel{width:min(75vw,1100px);max-width:75vw;max-height:75vh}
.dialog--travel .travel-grid__container{flex:1;min-height:0}
.travel-grid__container{flex:1;min-height:0;display:flex}
.travel-grid__scroll{width:100%;height:100%;overflow:auto;border-radius:12px;border:1px solid #e5e7eb;background:#fff}
.row{display:flex;gap:12px;flex-wrap:wrap}
.col{flex:1 1 280px}
.alert{padding:12px 14px;border-radius:10px;background:#fff7ed;border:1px solid #fdba74;color:#9a3412}
.success{padding:12px 14px;border-radius:10px;background:#ecfdf5;border:1px solid #86efac;color:#14532d}
.team-list{display:flex;flex-direction:column;gap:16px}
.team-item{display:flex;flex-direction:column;align-items:center;width:100%}
.team-card{width:100%;background:#fff;border:1px solid #e5e7eb;border-radius:var(--radius);padding:var(--pad);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;overflow-wrap:anywhere}
.travel-grid{width:100%;border-collapse:separate;border-spacing:0;min-width:400px}
.travel-grid th,.travel-grid td{border:1px solid #e5e7eb;padding:6px;text-align:center;background:#fff}
.travel-grid__corner{position:sticky;top:0;left:0;z-index:4;background:#f8fafc}
.travel-grid__header{position:sticky;top:0;z-index:3;background:#f8fafc;font-weight:600}
.travel-grid__team{position:sticky;left:0;z-index:2;background:#f8fafc;text-align:left;padding-left:10px;font-weight:600;min-width:160px}
.travel-grid__cell{background:#fff}
.travel-grid__cell--void{background:#f9fafb}
.travel-grid input{width:72px;padding:6px;text-align:right;border-radius:8px;border:1px solid #cbd5e1}
.schedule-grid{display:flex;flex-direction:column;gap:20px}
.schedule-grid__header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}
.schedule-grid__heading{display:flex;flex-direction:column;gap:4px}
.schedule-grid__title{margin:0;font-size:28px;font-weight:700}
.schedule-grid__subtitle{margin:4px 0 0;color:#475467;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.schedule-grid__actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.schedule-grid__csv-link,.schedule-grid__pdf-link{white-space:nowrap}
.schedule-grid__back-link{color:var(--primary);text-decoration:none;font-weight:600;display:inline-flex;align-items:center;gap:6px}
.schedule-grid__back-link:hover{text-decoration:underline}
.schedule-grid__table-wrapper{background:#fff;border:1px solid #e5e7eb;border-radius:var(--radius);padding:12px;overflow-x:auto;box-shadow:0 8px 24px rgba(16,24,40,.04)}
.schedule-grid__table{width:100%;border-collapse:separate;border-spacing:0;min-width:640px}
.schedule-grid__table thead th{position:sticky;top:0;background:#f8fafc;z-index:1}
.schedule-grid__header-cell{padding:10px 12px;font-size:13px;font-weight:700;color:#1d2939;text-align:center;border-bottom:2px solid #d0d5dd}
.schedule-grid__row{transition:background .2s ease}
.schedule-grid__row-label{padding:12px 16px;text-align:left;font-size:13px;font-weight:600;color:#1d2939;border-right:1px solid #d0d5dd;white-space:nowrap}
.schedule-grid__table tbody tr:last-child td,.schedule-grid__table tbody tr:last-child th{border-bottom:1px solid #d0d5dd}
.schedule-grid__row--green .schedule-grid__row-label,.schedule-grid__row--green .grid-cell{background:var(--grid-row-green);color:#101828}
.schedule-grid__row--blue .schedule-grid__row-label,.schedule-grid__row--blue .grid-cell{background:var(--grid-row-blue);color:#101828}
.grid-cell{padding:12px 14px;text-align:center;font-weight:600;border-right:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb;white-space:nowrap;color:#101828;background:transparent}
.schedule-grid__row .grid-cell--bye{background:var(--grid-bye);color:#fff}
.grid-cell--game{box-shadow:inset 0 -2px 0 rgba(8,92,172,.35)}
.grid-cell--empty{color:#98a2b3;background:#f8fafc}
.grid-cell--unknown{background:#f8fafc;color:#475467}
.schedule-grid__row .grid-cell--mark-h{background:var(--grid-mark-home);color:#fff}
.schedule-grid__row .grid-cell--mark-a{background:var(--grid-mark-away);color:#fff}
.schedule-grid__empty{padding:32px 16px;text-align:center;font-size:16px;color:#475467}
.build-review{display:flex;flex-direction:column;gap:18px}
.build-review__summary-header{display:flex;align-items:center;justify-content:space-between;gap:12px}
.build-review__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin:16px 0 0}
.build-review__grid dt{font-size:12px;font-weight:600;text-transform:uppercase;color:#475467;letter-spacing:.08em;margin-bottom:4px}
.build-review__grid dd{margin:0;font-size:15px;color:#101828;font-weight:600}
.build-review__summary{background:#f8fafc}
.build-review__primary{display:flex;flex-direction:column;align-items:center;text-align:center;padding:28px 24px}
.build-review__intro{max-width:420px;margin:8px auto 18px;color:#475467}
.build-review__stats{display:flex;flex-wrap:wrap;justify-content:center;gap:24px;margin-bottom:18px}
.build-stat{background:#fff;border:1px solid #e4e7ec;border-radius:18px;padding:18px 24px;min-width:220px;box-shadow:0 8px 24px rgba(16,24,40,.05);display:flex;flex-direction:column;gap:4px;align-items:center}
.build-stat__label{font-size:12px;font-weight:600;text-transform:uppercase;color:#475467;letter-spacing:.1em}
.build-stat__value{font-size:32px;font-weight:700;color:#101828}
.build-stat__note{font-size:13px;color:#667085}
.build-review__phase{font-size:14px;font-weight:600;color:#085cac}
.build-review__error{margin-top:10px;color:#c81b1f;font-weight:600}
.link-button{border:none;background:none;color:#085cac;font-size:14px;font-weight:600;padding:4px 0;cursor:pointer;text-decoration:underline;text-underline-offset:3px}
.link-button:hover{text-decoration:none}
.build-overlay{position:fixed;inset:0;background:rgba(247,247,249,.88);display:none;align-items:center;justify-content:center;z-index:60}
.build-overlay:not(.hidden){display:flex}
.build-overlay__panel{background:#fff;border-radius:20px;padding:32px 28px;box-shadow:0 20px 45px rgba(15,23,42,.12);text-align:center;max-width:360px;width:90%;display:flex;flex-direction:column;gap:16px}
.build-overlay__panel h2{margin:0;font-size:22px;font-weight:700;color:#101828}
.build-overlay__panel p{margin:0;color:#475467}
.build-overlay__panel--small{max-width:320px}
.build-overlay__metrics{display:flex;align-items:center;justify-content:center;gap:24px}
.build-overlay__label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;color:#475467;letter-spacing:.08em;margin-bottom:4px}
.build-overlay__value{font-size:20px;font-weight:700;color:#101828}
.build-overlay__actions{display:flex;justify-content:center;gap:12px}
.job-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px}
.job-list__item{border:1px solid #e4e7ec;border-radius:16px;padding:16px}
.job-list__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.job-list__title{font-weight:600;font-size:16px;color:#101828}
.job-list__meta{font-size:14px;color:#475467;margin-top:4px}
.job-list__progress-bar{width:100%;height:6px;border-radius:999px;background:#e4e7ec;overflow:hidden}
.job-list__progress-bar span{display:block;height:100%;background:#085cac;border-radius:999px}
.job-list__progress-meta{font-size:13px;color:#475467;margin-top:6px}
.job-list__actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:12px}
.job-list__status-message{font-size:13px;color:#c81b1f}
.job-list__empty{margin:0}
.queue-callout{border:1px dashed #085cac;border-radius:14px;padding:16px;background:#f7f7f9;margin-bottom:8px}
.queue-callout__label{font-size:13px;font-weight:600;text-transform:uppercase;color:#085cac;letter-spacing:.08em;margin:0 0 6px}
.queue-callout__meta{margin:0;font-size:24px;font-weight:700;color:#101828}
.queue-callout__hint{margin:8px 0 0;font-size:13px;color:#475467}
.jobs-table__error{font-size:12px;color:#c81b1f;margin-top:4px}
.table-responsive{overflow-x:auto}
