:root{
  --navy:#071225; --navy2:#0b1b36; --green:#7fb515; --green2:#b6df2a;
  --gold:#f8c449; --white:#fff; --muted:#9aa9bf; --line:rgba(255,255,255,.12);
  --bg:#071225; --card:#0d1f3d; --soft:#10284d; --danger:#ef4444; --ok:#22c55e;
}
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:#071225;color:#e9f2ff}
a{color:inherit;text-decoration:none} button,input,select,textarea{font-family:inherit}
.topbar{background:#050505;color:#f8fafc;padding:8px 0;font-size:13px;font-weight:300;text-transform:uppercase;letter-spacing:.12em;font-family:Arial,Helvetica,sans-serif}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.container{width:min(1180px,calc(100% - 32px));margin:auto}
.header{position:sticky;top:0;z-index:50;background:rgba(7,18,37,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand img{width:58px;height:58px;object-fit:contain;border-radius:14px;background:#fff;padding:5px}
.brand-logo-only img{width:170px;height:64px;border-radius:16px;padding:6px 10px}
.brand-logo-only{min-width:170px}
.brand-title{font-size:18px;font-weight:1000;line-height:1;text-transform:uppercase;letter-spacing:.04em}
.brand-subtitle{font-size:12px;color:#b8c7de;font-weight:800;margin-top:4px}
.nav{display:flex;gap:16px;align-items:center}
.nav a,.nav button{background:transparent;border:0;color:#dce9ff;font-weight:850;font-size:14px;cursor:pointer;padding:10px 12px;border-radius:999px}
.nav a:hover,.nav button:hover,.nav a.active{background:rgba(127,181,21,.17);color:#d7ff63}
.mobile-menu{display:none;background:rgba(255,255,255,.08);border:1px solid var(--line);color:#fff;border-radius:12px;padding:10px}
.hero{position:relative;overflow:hidden;background:
  radial-gradient(circle at 80% 5%,rgba(182,223,42,.38),transparent 28%),
  radial-gradient(circle at 12% 20%,rgba(248,196,73,.25),transparent 20%),
  linear-gradient(135deg,#071225 0%,#0b1b36 45%,#1b2a05 100%);
}
.hero:before{content:"";position:absolute;inset:0;background:url('../img/bg-portal-deportivo.svg') center/cover no-repeat;opacity:.20}
.hero-futbol:before{background:url('../img/bg-futbol-menores.svg') center/cover no-repeat;opacity:.22}

.hero-content{position:relative;z-index:1;padding:84px 0 72px;display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center}
.kicker{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(182,223,42,.35);background:rgba(182,223,42,.11);color:#d7ff63;border-radius:999px;padding:8px 13px;font-size:12px;font-weight:1000;text-transform:uppercase;letter-spacing:.08em}
h1{font-size:clamp(38px,7vw,82px);line-height:.92;margin:18px 0;font-weight:1000;letter-spacing:-.04em;text-transform:uppercase}
.hero p{color:#cbd8ec;font-size:18px;line-height:1.6;max-width:680px}
.actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:16px;padding:13px 18px;font-weight:950;cursor:pointer;transition:.18s}
.btn-primary{background:linear-gradient(135deg,var(--green2),var(--green));color:#071225;box-shadow:0 12px 30px rgba(127,181,21,.26)}
.btn-secondary{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.16);color:#fff}
.btn-small{padding:9px 12px;border-radius:12px;font-size:13px}
.btn-danger{background:rgba(239,68,68,.15);color:#fecaca;border:1px solid rgba(239,68,68,.25)}
.btn-disabled{opacity:.55;cursor:not-allowed}
.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.stat-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:22px;padding:20px;box-shadow:0 20px 50px rgba(0,0,0,.25)}
.stat-number{font-size:34px;font-weight:1000;color:#d7ff63}
.stat-label{color:#cbd8ec;font-weight:800;font-size:13px;text-transform:uppercase}
.section{padding:58px 0}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:24px}
.section-title{font-size:34px;font-weight:1000;letter-spacing:-.02em;margin:0;text-transform:uppercase}
.section-subtitle{margin:8px 0 0;color:#9fb1ca}
.grid{display:grid;gap:20px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035));border:1px solid rgba(255,255,255,.12);border-radius:26px;padding:22px;box-shadow:0 18px 40px rgba(0,0,0,.24)}
.card h3{margin:0 0 8px;font-size:22px}
.card p{margin:0;color:#b6c6dd;line-height:1.5}
.badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:950;text-transform:uppercase}
.badge-green{background:rgba(34,197,94,.15);color:#bbf7d0}.badge-gold{background:rgba(248,196,73,.16);color:#fde68a}.badge-blue{background:rgba(59,130,246,.15);color:#bfdbfe}
.champ-hero{position:relative;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.12);background:linear-gradient(135deg,rgba(7,18,37,.94),rgba(30,49,7,.92))}
.champ-hero:before{content:"";position:absolute;inset:0;background:url('../IMG/bg-campeonatos.svg') center/cover no-repeat;opacity:.22}
.champ-hero .container{position:relative;z-index:1;padding:64px 0}
.champ-card{position:relative;overflow:hidden;min-height:280px;display:flex;flex-direction:column;justify-content:space-between}
.champ-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(127,181,21,.18),transparent 44%);pointer-events:none}
.champ-card>*{position:relative}
.table-wrap{overflow:auto;border-radius:20px;border:1px solid rgba(255,255,255,.12)}
table{width:100%;border-collapse:collapse;min-width:760px;background:rgba(255,255,255,.04)}
th{background:rgba(127,181,21,.20);color:#d7ff63;text-transform:uppercase;font-size:12px;letter-spacing:.06em;text-align:left;padding:12px}
td{padding:12px;border-top:1px solid rgba(255,255,255,.08);color:#e7f0ff}
.score{font-weight:1000;color:#fff}
.page-title{padding:42px 0 26px}
.filters{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:18px}
.input,select,textarea{background:#0b1b36;border:1px solid rgba(255,255,255,.15);color:#fff;border-radius:14px;padding:12px 13px;outline:none;width:100%}
.input:focus,select:focus,textarea:focus{border-color:rgba(182,223,42,.65);box-shadow:0 0 0 3px rgba(182,223,42,.12)}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.form-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
label{display:block;color:#c9d8ee;font-weight:850;font-size:13px;margin-bottom:6px}
.login-shell{min-height:calc(100vh - 100px);display:grid;place-items:center;padding:50px 0;background:linear-gradient(180deg,#f8fafc,#eaf2f7);color:#071225}
.login-card{width:min(440px,100%);background:#ffffff;border:1px solid rgba(15,23,42,.10);border-radius:28px;padding:28px;box-shadow:0 24px 60px rgba(2,8,23,.18)}
.login-card .section-title{color:#071225}
.login-card .section-subtitle{color:#64748b}
.login-card label{color:#22324a}
.login-card .input{background:#f8fafc;border:1px solid #d7dee9;color:#071225}
.login-card .btn-secondary{background:#eef3f8;border:1px solid #d7dee9;color:#071225}
.panel-layout{display:grid;grid-template-columns:280px 1fr;min-height:100vh;background:#071225}
.sidebar{background:#071225;border-right:1px solid rgba(255,255,255,.12);padding:22px;position:sticky;top:0;height:100vh}
.side-brand{display:flex;gap:10px;align-items:center;margin-bottom:24px}.side-brand img{width:48px;height:48px;object-fit:contain;background:#fff;border-radius:14px;padding:4px}
.side-user{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:14px;margin-bottom:18px}
.side-user strong{display:block;color:#fff}.side-user span{display:block;color:#9fb1ca;font-size:12px;margin-top:3px}
.side-menu{display:grid;gap:8px}.side-menu button,.side-menu a{background:transparent;color:#dce9ff;border:0;text-align:left;padding:12px;border-radius:14px;font-weight:850;cursor:pointer}
.side-menu button.active,.side-menu a.active,.side-menu button:hover,.side-menu a:hover{background:rgba(127,181,21,.16);color:#d7ff63}
.panel-main{padding:28px}
.welcome{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:22px;background:linear-gradient(135deg,rgba(127,181,21,.18),rgba(255,255,255,.06));border:1px solid rgba(255,255,255,.14);border-radius:28px;padding:24px}
.welcome h1{font-size:34px;line-height:1.1;margin:0;text-transform:none;letter-spacing:-.02em}
.welcome p{margin:6px 0 0;color:#c8d8ee}
.tabs-content{display:none}.tabs-content.active{display:block}
.player-card{display:flex;gap:14px;align-items:center}.avatar{width:64px;height:64px;border-radius:18px;object-fit:cover;background:#fff}.player-card .avatar{flex:0 0 auto}
.avatar-fallback{width:64px;height:64px;border-radius:18px;background:linear-gradient(135deg,#b6df2a,#7fb515);color:#071225;font-weight:1000;display:grid;place-items:center}
.category-checks{display:flex;flex-wrap:wrap;gap:10px}
.category-check{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:8px 11px;font-weight:900;color:#e9f2ff;white-space:nowrap}
.category-check input{margin:0;accent-color:#b6df2a}
.readonly-field{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.10);border-radius:16px;padding:13px;color:#eef6ff;font-weight:800;min-height:46px}
.match-card{display:grid;gap:12px}.match-meta{display:flex;gap:8px;flex-wrap:wrap}.match-teams{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:center;font-size:18px;font-weight:1000}.match-teams .away{text-align:right}
.locked{opacity:.55}.convocado{border-color:rgba(34,197,94,.45);box-shadow:0 0 0 1px rgba(34,197,94,.16),0 18px 40px rgba(0,0,0,.24)}
.modal{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;padding:18px;background:rgba(0,0,0,.72)}
.modal.open{display:flex}.modal-dialog{width:min(980px,100%);max-height:92vh;overflow:auto;background:#08172e;border:1px solid rgba(255,255,255,.15);border-radius:28px;box-shadow:0 40px 100px rgba(0,0,0,.55)}
.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#020816;color:white;padding:18px 22px;border-radius:28px 28px 0 0;border-bottom:1px solid rgba(255,255,255,.12)}
.modal-header h3{margin:0}.modal-close{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);color:white;width:38px;height:38px;border-radius:12px;cursor:pointer;font-size:22px}.modal-body{padding:22px}
.roster-columns{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.roster-list{display:grid;gap:10px}.roster-item{display:flex;justify-content:space-between;align-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);border-radius:15px;padding:10px}
.footer{border-top:1px solid rgba(255,255,255,.12);padding:44px 0 22px;background:#050d1c;color:#8fa2bc}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:22px;align-items:start}.footer strong{color:#fff}.footer-title{font-size:18px;font-weight:950;text-transform:uppercase;letter-spacing:.04em}.footer-links{display:grid;gap:8px}.footer-links a{color:#cbd8ec}.footer-links a:hover{color:#d7ff63}.footer-bottom{border-top:1px solid rgba(255,255,255,.10);margin-top:26px;padding-top:18px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;color:#7f90a8;font-size:13px}
.toast{position:fixed;right:18px;bottom:18px;background:#0b1b36;border:1px solid rgba(182,223,42,.25);border-radius:16px;padding:14px 16px;color:#fff;display:none;z-index:200}.toast.show{display:block}
@media(max-width:860px){
  .nav{display:none}.mobile-menu{display:block}.hero-content,.grid-3,.grid-2,.form-grid,.form-grid-3,.roster-columns,.footer-grid{grid-template-columns:1fr}
  .panel-layout{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.panel-main{padding:18px}.welcome{display:block}.footer-grid{display:block}.match-teams{grid-template-columns:1fr;text-align:left}.match-teams .away{text-align:left}
}


/* Ajustes solicitados: login más claro y cabecera superior negra */
#loginModal .modal-dialog{background:#ffffff;color:#071225;border:1px solid rgba(15,23,42,.12)}
#loginModal .modal-body{background:#ffffff;color:#071225;border-radius:0 0 28px 28px}
#loginModal .modal-body p,#loginModal .modal-body .section-subtitle{color:#64748b}
#loginModal .modal-body label{color:#22324a}
#loginModal .modal-body .input{background:#f8fafc;border:1px solid #d7dee9;color:#071225}
#loginModal .modal-body .btn-secondary{background:#eef3f8;border:1px solid #d7dee9;color:#071225}
@media(max-width:860px){.topbar-inner{font-size:11px}.brand-logo-only img{width:138px;height:56px}.brand-logo-only{min-width:138px}}

/* Mejora visual solicitada: logo sin recuadro blanco y barra superior más fina */
.topbar{font-weight:200;letter-spacing:.14em}
.brand img,.brand-logo-only img{background:transparent!important;padding:0!important;border-radius:0!important;box-shadow:none!important}
.brand-logo-only img{width:178px;height:66px;object-fit:contain}
.brand-logo-only{min-width:178px}

/* Login: copy más natural */
.login-card .section-subtitle{font-size:14px}

/* Panel entrenador más claro */
.panel-layout{background:#f5f7fb;color:#102033}
.sidebar{background:#ffffff;border-right:1px solid #e4eaf2;box-shadow:10px 0 30px rgba(15,23,42,.04)}
.side-brand strong,.side-user strong{color:#102033}
.side-brand span,.side-user span{color:#64748b;font-size:12px}
.side-brand img{background:transparent!important;padding:0!important;border-radius:12px;object-fit:contain;border:1px solid #e7edf5}
.side-user{background:#f8fafc;border:1px solid #e4eaf2}
.side-menu button,.side-menu a{color:#26364d}
.side-menu button.active,.side-menu a.active,.side-menu button:hover,.side-menu a:hover{background:rgba(127,181,21,.13);color:#29520b}
.panel-main{background:#f5f7fb;color:#102033}
.panel-main .card{background:#ffffff;border:1px solid #e2e8f0;box-shadow:0 18px 42px rgba(15,23,42,.08);color:#102033}
.panel-main .card p,.panel-main .section-subtitle,.panel-main .welcome p{color:#64748b}
.panel-main .section-title,.panel-main h1,.panel-main h2,.panel-main h3{color:#102033}
.panel-main label{color:#34445c}
.panel-main .input,.panel-main select,.panel-main textarea{background:#f8fafc;border:1px solid #d9e2ee;color:#102033}
.panel-main .readonly-field{background:#f8fafc;border:1px solid #e0e7f0;color:#102033}
.panel-main .welcome{background:linear-gradient(135deg,#ffffff,#eef7df);border:1px solid #e2e8f0;box-shadow:0 18px 42px rgba(15,23,42,.08)}
.panel-main .category-check{background:#f8fafc;border:1px solid #dfe7f1;color:#102033}
.panel-main .btn-secondary{background:#edf3f8;border:1px solid #d8e2ef;color:#102033}
.panel-main .btn-danger{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
.panel-main .roster-item{background:#f8fafc;border:1px solid #e0e7f0;color:#102033}
.panel-main .modal .card{background:#ffffff}
.category-pill{display:inline-flex;align-items:center;background:#edf7d9;border:1px solid #cbeaa1;color:#30580f;border-radius:999px;padding:8px 12px;font-weight:900;margin:3px 6px 3px 0;white-space:nowrap}
.category-list-readonly{display:flex;gap:8px;flex-wrap:wrap;align-items:center;min-height:46px}
.profile-summary{display:grid;grid-template-columns:120px 1fr;gap:20px;align-items:start}
.team-crest-large{width:110px;height:110px;object-fit:contain;border-radius:24px;background:#f8fafc;border:1px solid #e0e7f0;padding:8px}
.field-help{font-size:12px!important;color:#64748b!important;margin:6px 0 0!important;line-height:1.4!important}
.player-filters{align-items:center;margin-top:-8px;margin-bottom:16px}
.player-filters .btn.active{background:linear-gradient(135deg,var(--green2),var(--green));color:#071225;border:0}
.round-card{margin-bottom:18px}
.round-card .grid{margin-top:12px}

/* Mantener modales de convocatoria oscuros, pero el modal de jugador en estilo claro */
#playerModal .modal-dialog{background:#ffffff;color:#102033;border:1px solid rgba(15,23,42,.12)}
#playerModal .modal-body{background:#ffffff;color:#102033;border-radius:0 0 28px 28px}
#playerModal label{color:#34445c}
#playerModal .input,#playerModal select{background:#f8fafc;border:1px solid #d9e2ee;color:#102033}
#playerModal .category-check{background:#f8fafc;border:1px solid #dfe7f1;color:#102033}

@media(max-width:860px){
  .brand-logo-only img{width:142px;height:56px}.brand-logo-only{min-width:142px}
  .profile-summary{grid-template-columns:1fr}.team-crest-large{width:92px;height:92px}
}


/* Correcciones UX solicitadas - equipos, sidebar y contraste */
.topbar{font-weight:100!important;letter-spacing:.15em;color:#f1f5f9}
.topbar span{font-weight:100!important}

/* Panel entrenador: punto medio, no tan oscuro ni tan claro */
.panel-layout{background:#eef3f8;color:#102033}
.sidebar{background:linear-gradient(180deg,#10243f,#0b1b30)!important;border-right:1px solid rgba(255,255,255,.10);box-shadow:12px 0 34px rgba(15,23,42,.12)}
.side-brand strong,.side-user strong{color:#ffffff!important}
.side-brand span,.side-user span{color:#c7d5e8!important}
.side-brand img{background:transparent!important;border:0!important;padding:0!important;border-radius:0!important;box-shadow:none!important;object-fit:contain}
.side-user{background:rgba(255,255,255,.075)!important;border:1px solid rgba(255,255,255,.14)!important}
.side-menu button,.side-menu a{color:#e8f1ff!important}
.side-menu button.active,.side-menu a.active,.side-menu button:hover,.side-menu a:hover{background:rgba(182,223,42,.18)!important;color:#d7ff63!important}
.panel-main{background:#eef3f8;color:#102033}
.panel-main .welcome{background:linear-gradient(135deg,#ffffff,#eef8df);border:1px solid #dce6f1;box-shadow:0 16px 34px rgba(15,23,42,.08)}

/* Insignias sin recuadros */
.team-crest-large{background:transparent!important;border:0!important;padding:0!important;border-radius:0!important;object-fit:contain}

/* Cards públicas de equipos */
.team-public-card{display:grid;grid-template-columns:1fr 92px;gap:18px;align-items:center;min-height:150px}
.team-public-info h3{margin-bottom:10px}.team-public-info p{margin-bottom:12px}
.team-cat-badges{display:flex;flex-wrap:wrap;gap:8px}
.team-public-logo{width:86px;height:86px;object-fit:contain;justify-self:end;background:transparent;border:0;padding:0;border-radius:0;filter:drop-shadow(0 10px 18px rgba(0,0,0,.22))}

/* Filtros de jugadores alineados */
.player-filter-block{margin:-8px 0 16px}.player-filter-block .field-help{margin-bottom:10px!important}.player-filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:0!important}

/* Más contraste para campeonatos, próximos partidos y convocatorias */
#tab-campeonatos .card,#tab-partidos .card.round-card,#tab-convocatorias .match-card{border:1px solid #d4e0ec;box-shadow:0 18px 42px rgba(15,23,42,.10)}
#tab-convocatorias .match-card,#tab-partidos .match-card{background:linear-gradient(135deg,#ffffff 0%,#f4f8fc 58%,#eef7df 100%)}
#tab-convocatorias .badge,#tab-partidos .badge,#tab-campeonatos .badge{box-shadow:inset 0 0 0 1px rgba(0,0,0,.05)}
.panel-main .badge-green{background:#dcfce7!important;color:#166534!important;border:1px solid #86efac!important}
.panel-main .badge-blue{background:#dbeafe!important;color:#1e40af!important;border:1px solid #93c5fd!important}
.panel-main .badge-gold{background:#fef3c7!important;color:#92400e!important;border:1px solid #fcd34d!important}
.match-teams{color:#0f1f36}.match-card p{color:#4b5d75!important}
.convocado{border-color:#22c55e!important;box-shadow:0 0 0 1px rgba(34,197,94,.20),0 18px 42px rgba(15,23,42,.10)!important}
.locked{opacity:.72}

@media(max-width:860px){.team-public-card{grid-template-columns:1fr}.team-public-logo{justify-self:start}}


/* Ajustes calendario / convocatorias con más contraste */
.match-card-visual{
  background:linear-gradient(135deg,#0f3b2e 0%,#14532d 52%,#193b17 100%)!important;
  color:#ffffff!important;
  border:1px solid rgba(134,239,172,.35)!important;
  box-shadow:0 18px 42px rgba(15,23,42,.22)!important;
}
.match-card-visual.locked{opacity:.92}
.match-card-visual.convocado{box-shadow:0 0 0 2px rgba(34,197,94,.45),0 18px 42px rgba(15,23,42,.22)!important}
.match-card-visual .badge-green{
  background:#16a34a!important;
  color:#ffffff!important;
  border:1px solid rgba(255,255,255,.18)!important;
}
.match-card-visual .match-category,.match-card-visual p{color:#d8ffe3!important}
.match-vs-logos{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center;margin:10px 0}
.match-vs-logos b{font-size:14px;background:rgba(255,255,255,.14);padding:8px 10px;border-radius:999px;color:#ffffff}
.team-side{display:flex;gap:10px;align-items:center;font-weight:900;color:#ffffff;min-width:0}
.team-side.right{justify-content:flex-end;text-align:right}
.team-side img{width:42px;height:42px;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(0,0,0,.28))}
.team-side span{overflow:hidden;text-overflow:ellipsis}
.round-card{background:#f8fafc!important;border:1px solid #d9e5d6!important}
.round-card > .section-head .badge{background:#16a34a!important;color:#fff!important}
#tab-partidos .round-card{background:linear-gradient(180deg,#ffffff,#f3f8ef)!important}
#tab-campeonatos .card{background:linear-gradient(135deg,#ffffff 0%,#f4faef 100%)!important}
.fixture-hero .match-card-visual .team-side span,.hero-futbol .match-card-visual .team-side span{color:#fff!important}

/* Ajustes finales solicitados: panel, cards, logos y footer */
.side-brand img,
.team-public-logo,
.team-side img,
.team-crest-large,
.avatar{
  border-radius:16px!important;
}
.side-brand img{width:54px!important;height:54px!important;object-fit:contain!important;filter:drop-shadow(0 8px 16px rgba(0,0,0,.24));}
.side-brand span#sidebarTeamName{font-size:12px!important;line-height:1.25;max-width:155px;display:block;white-space:normal;color:#dce8f7!important;}
.team-crest-large{border-radius:22px!important;filter:drop-shadow(0 10px 20px rgba(15,23,42,.15));}
.team-public-logo{border-radius:18px!important;filter:drop-shadow(0 10px 18px rgba(0,0,0,.18));}
.team-side img{border-radius:14px!important;background:rgba(255,255,255,.82);padding:4px;}

/* Cards de partidos más claras; badges con verde oscuro */
.match-card-visual{
  background:linear-gradient(135deg,#ffffff 0%,#f7fbf4 55%,#edf8e5 100%)!important;
  color:#122033!important;
  border:1px solid #d7e6cc!important;
  box-shadow:0 16px 36px rgba(15,23,42,.10)!important;
}
.match-card-visual .badge-green,
.round-card > .section-head .badge,
#tab-convocatorias .badge,
#tab-partidos .badge{
  background:#14532d!important;
  color:#ffffff!important;
  border:1px solid rgba(255,255,255,.12)!important;
}
.match-card-visual .match-category,
.match-card-visual p,
.match-card p{color:#52657d!important;}
.match-vs-logos b{background:#14532d!important;color:#fff!important;}
.team-side,
.team-side span{color:#122033!important;}
.match-card-visual.convocado{border-color:#22c55e!important;box-shadow:0 0 0 2px rgba(34,197,94,.20),0 16px 36px rgba(15,23,42,.10)!important;}
.match-card-visual.locked{opacity:.72;filter:saturate(.85);}
.status-badge{display:inline-flex;align-items:center;border-radius:999px;padding:8px 12px;font-size:12px;font-weight:900;white-space:nowrap;}
.status-pending{background:#ffedd5;color:#9a3412;border:1px solid #fed7aa;}
.status-ready{background:#dcfce7;color:#166534;border:1px solid #86efac;}
.btn-disabled{pointer-events:none;opacity:.62;}
.player-card-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;}
.btn-small{padding:7px 10px;font-size:12px;border-radius:10px;}

/* Footer con logo */
.footer-logo{width:150px;max-height:74px;object-fit:contain;display:block;margin-bottom:12px;filter:drop-shadow(0 8px 18px rgba(0,0,0,.18));}

/* Fixture como cards */
.fixture-rounds{display:grid;gap:22px;}
.fixture-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;}
.fixture-match-card{background:linear-gradient(135deg,#ffffff,#f6fbf2);border:1px solid #dbe9d1;border-radius:22px;padding:18px;box-shadow:0 14px 32px rgba(15,23,42,.08);}
.fixture-match-card.played{border-color:#9bd483;}
.fixture-match-card .score-line{font-size:22px;font-weight:1000;color:#14532d;}
.filter-label{font-weight:900;color:#203047;}
@media(max-width:860px){.fixture-grid{grid-template-columns:1fr}.footer-logo{width:132px}}

/* Hero campeonato: texto claro sobre fondo deportivo */
.hero-futbol h1,.hero-futbol p,.hero-futbol .kicker{color:#ffffff!important;}
.hero-futbol .btn-secondary{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);color:#fff;}


/* =========================================================
   CORRECCIÓN: fondos reales detrás del SVG decorativo
   Sube las imágenes aquí:
   assets/img/backgrounds/bg-index-deportivo.jpg
   assets/img/backgrounds/bg-futbol-menores-real.jpg
========================================================= */
.hero{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 80% 5%,rgba(182,223,42,.28),transparent 28%),
    radial-gradient(circle at 12% 20%,rgba(248,196,73,.18),transparent 20%),
    linear-gradient(135deg,rgba(7,18,37,.88) 0%,rgba(11,27,54,.84) 45%,rgba(27,42,5,.82) 100%),
    url('../img/backgrounds/bg-index-deportivo.jpg') center/cover no-repeat !important;
}
.hero.hero-futbol{
  background:
    radial-gradient(circle at 82% 8%,rgba(182,223,42,.24),transparent 28%),
    radial-gradient(circle at 10% 18%,rgba(248,196,73,.16),transparent 22%),
    linear-gradient(135deg,rgba(7,18,37,.88) 0%,rgba(11,27,54,.84) 45%,rgba(27,42,5,.82) 100%),
    url('../img/backgrounds/bg-futbol-menores-real.jpg') center/cover no-repeat !important;
}
.hero:before{z-index:1;opacity:.18!important;pointer-events:none;}
.hero.hero-futbol:before{z-index:1;opacity:.16!important;pointer-events:none;}
.hero-content,.hero .container{position:relative;z-index:2;}

/* Fondos de campeonatos con imagen opcional */
.champ-hero{
  background:
    linear-gradient(135deg,rgba(7,18,37,.90),rgba(30,49,7,.86)),
    url('../img/backgrounds/bg-index-deportivo.jpg') center/cover no-repeat !important;
}
.champ-hero:before{z-index:1;opacity:.18!important;}
.champ-hero .container{position:relative;z-index:2;}

/* Bordes y hover para cards operativas */
.match-card-visual,
.player-card,
.round-card .match-card-visual,
#coachConvocatorias .match-card-visual,
#coachCalendar .match-card-visual{
  border:1.5px solid rgba(21,128,61,.45)!important;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.match-card-visual:hover,
.player-card:hover,
.round-card .match-card-visual:hover,
#coachConvocatorias .match-card-visual:hover,
#coachCalendar .match-card-visual:hover{
  transform:translateY(-2px);
  border-color:rgba(21,128,61,.80)!important;
  box-shadow:0 18px 44px rgba(15,23,42,.16)!important;
}
.team-side img,.team-public-logo,.team-crest-large,.side-brand img,.avatar{
  border-radius:16px!important;
}

/* =========================================================
   Ajustes solicitados: fixture, resultados, tablas y roster
========================================================= */
/* Badges públicos con texto legible */
.fixture-match-card .badge,
.results-filters select,
.filters select,
#standingCategory{
  color:#0f2b1b!important;
}
.fixture-match-card .badge-green,
.fixture-match-card .match-meta .badge,
.results-filters + .table-wrap th,
.round-card > .section-head .badge{
  background:#dcfce7!important;
  color:#14532d!important;
  border:1px solid #86efac!important;
}
.fixture-match-card{
  border:1.5px solid rgba(21,128,61,.42)!important;
  background:linear-gradient(135deg,#ffffff 0%,#f8fcf6 60%,#eef9e7 100%)!important;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.fixture-match-card:hover{
  transform:translateY(-2px);
  border-color:rgba(21,128,61,.82)!important;
  box-shadow:0 20px 48px rgba(15,23,42,.16)!important;
}
.fixture-match-card .team-side span{color:#122033!important;}
.fixture-match-card .result-pill,
.fixture-match-card .match-vs-logos b{
  background:#14532d!important;
  color:#ffffff!important;
  min-width:56px;
  text-align:center;
}
.match-status-text{
  margin-top:10px!important;
  color:#35465f!important;
  font-size:13px;
}
.match-status-text b{color:#14532d;}
.results-filters{align-items:center;margin-bottom:18px;}
.results-filters select,
#filterCategory,
#filterRound,
#standingCategory{
  background:#ffffff!important;
  border:1px solid #cbd5e1!important;
  color:#0f172a!important;
  font-weight:750;
}
.filter-label{
  color:#ffffff!important;
  font-weight:900!important;
  letter-spacing:.02em;
}
.roster-counter{
  margin:0 0 10px;
  padding:8px 10px;
  border-radius:12px;
  background:#ecfdf5;
  color:#166534;
  border:1px solid #bbf7d0;
  font-size:13px;
  font-weight:900;
}
.roster-counter.danger{background:#fef2f2;color:#991b1b;border-color:#fecaca;}
.roster-item .btn[disabled]{opacity:.45;cursor:not-allowed;filter:grayscale(.2);}
