:root{--ink: #0a1628;--ink-muted: #475569;--white: #ffffff;--surface: #f8fafc;--border: #e2e8f0;--accent: #0ea5e9;--accent-dark: #0284c7;--radius-pill: 999px;--radius-card: 1rem;--shadow-soft: 0 16px 40px rgba(10, 22, 40, .08)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100svh;font-family:Inter,system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--surface);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100svh}a{color:inherit;text-decoration:none}button{font-family:inherit}.topbar--solid{position:relative;width:100%;background:var(--ink)}.topbar--solid .topbar__inner{padding:1rem 1.5rem}.topbar--solid .brand,.topbar--solid .nav__link{text-shadow:none}.nav__user{font-size:.75rem;font-weight:500;color:#ffffffd9;max-width:10rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav__user--link{text-decoration:none;border-radius:var(--radius-pill);padding:.35rem .65rem;transition:background .15s ease,color .15s ease}.nav__user--link:hover{color:var(--white);background:#ffffff1f}.topbar--solid .nav__user{color:#ffffffbf}.nav__link--accent{padding:.45rem 1rem;background:#ffffff26;border:1px solid rgba(255,255,255,.35);border-radius:var(--radius-pill)}.nav__link--button{background:none;border:none;cursor:pointer;font:inherit}.auth-page{min-height:100svh;display:flex;flex-direction:column}.auth-hero{position:relative;min-height:min(38vh,320px);display:flex;align-items:flex-end}.auth-hero__bg{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#1a2a3a;background-size:cover;background-position:center 30%;background-repeat:no-repeat}.auth-hero__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#000000e0,#00000073 45%,#0003);pointer-events:none}.auth-hero__inner{position:relative;z-index:2;width:100%;max-width:480px;margin:0 auto;padding:5.5rem 1.5rem 2rem;text-align:center}.auth-hero__title{margin:0;font-size:clamp(1.75rem,5vw,2.25rem);font-weight:800;letter-spacing:-.03em;color:var(--white);text-shadow:0 2px 16px rgba(0,0,0,.5)}.auth-hero__subtitle{margin:.65rem 0 0;font-size:.95rem;line-height:1.45;color:#ffffffe6}.auth-body{flex:1;background:var(--surface);padding:2rem 1.5rem 3rem}.auth-body__inner{max-width:420px;margin:0 auto}.auth-form{display:flex;flex-direction:column;gap:1.15rem}.auth-field{display:flex;flex-direction:column;gap:.4rem;text-align:left}.auth-field label{font-size:.82rem;font-weight:600;color:var(--ink)}.auth-field input{width:100%;padding:.75rem 1rem;font-size:.95rem;font-family:inherit;color:var(--ink);background:var(--white);border:1px solid var(--border);border-radius:.65rem;transition:border-color .2s,box-shadow .2s}.auth-field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #0ea5e933}.auth-field input::placeholder{color:#94a3b8}.auth-error{margin:0;padding:.75rem 1rem;font-size:.88rem;line-height:1.4;color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:.65rem}.auth-success{margin:0;padding:.75rem 1rem;font-size:.88rem;line-height:1.4;color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:.65rem}.auth-forgot{margin:-.35rem 0 0;text-align:right;font-size:.85rem}.auth-forgot a{color:var(--accent-dark);font-weight:500}.auth-forgot a:hover{text-decoration:underline}.auth-form-link-btn{display:block;width:100%;text-align:center;text-decoration:none}.auth-form .btn{width:100%;min-width:unset;margin-top:.25rem}.auth-form .btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.auth-switch{margin:1.5rem 0 0;font-size:.9rem;text-align:center;color:var(--ink-muted)}.auth-switch__link{font-weight:600;color:var(--accent-dark)}.auth-switch__link:hover{text-decoration:underline}.auth-back{display:inline-flex;align-items:center;gap:.35rem;margin-bottom:1.25rem;font-size:.85rem;font-weight:500;color:var(--ink-muted)}.auth-back:hover{color:var(--ink)}.auth-loading{min-height:100svh;display:flex;align-items:center;justify-content:center;background:var(--surface);color:var(--ink-muted);font-size:.95rem}.landing{color:var(--ink);overflow-x:hidden}.topbar--over-hero{position:absolute;top:0;left:0;right:0;z-index:20;width:100%}.topbar__shade{position:absolute;top:0;left:50%;transform:translate(-50%);width:100vw;height:100%;min-height:5.5rem;background:linear-gradient(180deg,rgba(0,0,0,.65) 0%,rgba(0,0,0,.35) 55%,transparent 100%);pointer-events:none}.topbar__inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:1200px;margin:0 auto;padding:1rem 1.5rem}.brand{font-size:1.05rem;font-weight:800;letter-spacing:.03em;color:#fff;text-shadow:0 0 20px rgba(0,0,0,.8),0 2px 4px rgba(0,0,0,.9),0 1px 0 rgba(0,0,0,.5);white-space:nowrap}.nav{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.5rem 1.25rem}.nav__link{font-size:.85rem;font-weight:600;color:#fff;text-shadow:0 0 16px rgba(0,0,0,.75),0 1px 3px rgba(0,0,0,.9);padding:.4rem .65rem;border-radius:.35rem;transition:background .2s,transform .15s}.nav__link:hover{background:#ffffff26;transform:translateY(-1px)}@media (max-width: 520px){.nav__link{font-size:.72rem}}.btn{display:inline-flex;align-items:center;justify-content:center;min-width:12rem;padding:.9rem 1.75rem;font-size:.95rem;font-weight:600;border-radius:var(--radius-pill);border:2px solid transparent;cursor:pointer;transition:transform .15s ease,background .2s ease,box-shadow .2s ease;text-align:center}.btn:hover{transform:translateY(-2px)}.btn--primary{background:var(--ink);color:var(--white);box-shadow:var(--shadow-soft)}.btn--primary:hover{background:#152a47}.btn--secondary{background:var(--white);color:var(--ink);border-color:var(--ink)}.btn--secondary:hover{background:var(--surface)}.hero{position:relative;min-height:min(72vh,640px);display:flex;align-items:flex-end}.hero__bg{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#1a2a3a;background-size:cover;background-position:center 35%;background-repeat:no-repeat}.hero__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.55) 28%,rgba(0,0,0,.25) 52%,transparent 78%);pointer-events:none}.hero__inner{position:relative;z-index:2;width:100%;max-width:1200px;margin:0 auto;padding:6rem 1.5rem 3.5rem}.hero__title{margin:0;font-size:clamp(2.5rem,10vw,5rem);font-weight:800;line-height:1;letter-spacing:-.03em;color:var(--white);text-shadow:0 2px 24px rgba(0,0,0,.45)}.hero__tagline{margin:1rem 0 0;max-width:28rem;font-size:clamp(1rem,2.5vw,1.25rem);font-weight:500;line-height:1.4;color:#fffffff2;text-shadow:0 1px 12px rgba(0,0,0,.4)}.instrucciones{background:var(--surface);padding:3rem 1.5rem 4rem}.instrucciones__inner{max-width:1100px;margin:0 auto}.quiniela-intro{margin-bottom:2.5rem;text-align:center}.quiniela-intro__title{margin:0 0 1rem;font-size:clamp(1.35rem,3.5vw,1.75rem);font-weight:700;letter-spacing:-.02em;color:var(--ink)}.quiniela-intro__text{margin:0 0 1rem;max-width:52rem;margin-left:auto;margin-right:auto;font-size:1rem;line-height:1.65;color:var(--ink-muted)}.quiniela-intro__text:last-child{margin-bottom:0}.quiniela-intro__text strong{color:var(--ink);font-weight:600}.instrucciones__heading{margin:0 0 1.5rem;font-size:clamp(1.35rem,3.5vw,1.75rem);font-weight:700;letter-spacing:-.02em;color:var(--ink);text-align:center}.pasos{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;align-items:stretch}@media (max-width: 768px){.pasos{grid-template-columns:1fr}}.paso{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.35rem 1.1rem;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-soft);text-align:center}.paso__numero{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;font-size:1rem;font-weight:700;color:var(--white);background:var(--accent);border-radius:50%}.paso__content{display:flex;flex-direction:column;flex:1;width:100%;min-width:0}.paso__titulo{margin:0 0 .65rem;font-size:1.05rem;font-weight:700;color:var(--ink)}.paso__texto{flex:1;width:100%;margin:0;color:var(--ink-muted);font-size:.88rem;line-height:1.55;text-align:left}.instrucciones-aviso{margin-top:2rem;padding:1.25rem 1.35rem;background:#fffbeb;border:1px solid #fcd34d;border-radius:var(--radius-card)}.instrucciones-aviso__heading{margin:0 0 .75rem;font-size:.95rem;font-weight:700;color:var(--ink)}.instrucciones-aviso__lista{margin:0;padding-left:1.25rem;color:var(--ink-muted);font-size:.88rem;line-height:1.6}.instrucciones-aviso__lista li+li{margin-top:.5rem}.acciones{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:2.5rem;padding-top:.5rem}.anchor{display:block;position:relative;top:-5rem;visibility:hidden}#instrucciones,#mis-ligas,#crear-liga,#unirse-liga,#crear-liga-form,#contacto{scroll-margin-top:5rem}.footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem;font-size:.85rem;color:var(--ink-muted);background:var(--white);border-top:1px solid var(--border)}.footer__dot{opacity:.5}.footer__link{font-weight:500;color:var(--accent-dark);transition:color .2s}.footer__link:hover{color:var(--accent);text-decoration:underline}.home-auth-hint{margin:1.75rem 0 0;text-align:center;font-size:.9rem;color:var(--ink-muted)}.partido-card{padding:1.25rem 1.2rem;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-soft)}.partido-card--abierto{border-color:#0ea5e973}.partido-card--pronosticado{border-color:#16653459}.partido-card--cerrado{opacity:.92}.partido-card--finalizado{border-color:var(--border)}.partido-card--en_vivo{border-color:#dc262673;box-shadow:0 0 0 1px #dc262614}.partido-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.partido-card__fecha{display:block;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-muted)}.partido-card__equipos{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem .5rem;margin:.35rem 0 0;font-size:1.05rem;font-weight:700;color:var(--ink)}.partido-card__vs{font-size:.82rem;font-weight:600;color:var(--ink-muted)}.partido-card__badge{flex-shrink:0;padding:.25rem .6rem;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius-pill)}.partido-card__badge--abierto{color:var(--accent-dark);background:#0ea5e91f}.partido-card__badge--pronosticado{color:#166534;background:#dcfce7}.partido-card__badge--cerrado{color:#92400e;background:#fef3c7}.partido-card__badge--en_vivo{color:#991b1b;background:#fee2e2;animation:partido-live-pulse 2s ease-in-out infinite}@keyframes partido-live-pulse{0%,to{opacity:1}50%{opacity:.75}}.partido-card__badge--finalizado{color:var(--ink-muted);background:var(--surface)}.partido-card__hint{margin:0 0 .85rem;font-size:.82rem;color:var(--ink-muted);line-height:1.45}.partido-card__form{display:flex;flex-direction:column;gap:.85rem}.partido-card__marcador{display:flex;align-items:flex-end;justify-content:center;gap:.75rem}.partido-card__input-wrap{display:flex;flex-direction:column;align-items:center;gap:.35rem;flex:1;max-width:7rem}.partido-card__input-label{font-size:.72rem;font-weight:600;color:var(--ink-muted);text-align:center;line-height:1.2}.partido-card__input-wrap input{width:100%;padding:.65rem;font-size:1.25rem;font-weight:700;font-family:inherit;text-align:center;color:var(--ink);background:var(--surface);border:1px solid var(--border);border-radius:.65rem}.partido-card__input-wrap input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #0ea5e933}.partido-card__sep{font-size:1.25rem;font-weight:700;color:var(--ink-muted);padding-bottom:.65rem}.partido-card__actions{display:flex;flex-wrap:wrap;gap:.65rem}.partido-card__submit{min-width:unset;padding:.65rem 1.25rem;font-size:.88rem}.partido-card__edit-btn{margin-top:.85rem;min-width:unset;padding:.55rem 1rem;font-size:.85rem}.fecha-filtro{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}.fecha-filtro__btn{padding:.45rem .9rem;font-size:.82rem;font-weight:600;font-family:inherit;color:var(--ink-muted);background:var(--white);border:1px solid var(--border);border-radius:var(--radius-pill);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.fecha-filtro__btn:hover{border-color:var(--accent);color:var(--ink)}.fecha-filtro__btn.is-active{color:var(--white);background:var(--ink);border-color:var(--ink)}.partidos-count{margin:0 0 1rem;font-size:.85rem;color:var(--ink-muted)}.partido-card__error{margin:0;padding:.65rem .85rem;font-size:.85rem;color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem}.partido-card__resultado{padding-top:.15rem}.partido-card__label{margin:0 0 .25rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-muted)}.partido-card__label--muted{color:#94a3b8}.partido-card__score{margin:0;font-size:1.5rem;font-weight:800;letter-spacing:.02em;color:var(--ink);font-variant-numeric:tabular-nums}.partido-card__score--live{font-size:2rem;color:#b91c1c}.partido-card__label--live{color:#b91c1c}.partido-card__resultado--live{padding:.5rem .75rem;background:#fef2f2;border-radius:.65rem;border:1px solid #fecaca}.partido-card__puntos{margin:.35rem 0 0;font-size:.9rem;font-weight:700;color:#166534}.partido-card__final-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 420px){.partido-card__final-grid{grid-template-columns:1fr}}.partidos-grid{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1rem}.liga-section+.liga-section{margin-top:2.5rem}.confirm-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1.25rem;background:#0a16288c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.confirm-dialog{width:min(100%,22rem);padding:1.35rem 1.25rem 1.15rem;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:0 24px 48px #0a16282e}.confirm-dialog__title{margin:0 0 .65rem;font-size:1.05rem;font-weight:700;color:var(--ink)}.confirm-dialog__message{margin:0 0 1.25rem;font-size:.92rem;line-height:1.5;color:var(--ink-muted)}.confirm-dialog__error{margin:-.75rem 0 1rem;padding:.65rem .75rem;font-size:.85rem;line-height:1.4;color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem}.confirm-dialog__actions{display:flex;justify-content:flex-end;gap:.65rem}.confirm-dialog__btn{min-width:unset;padding:.55rem 1rem;font-size:.88rem}.confirm-dialog__btn--danger{color:#fff;background:#dc2626;border-color:#dc2626}.confirm-dialog__btn--danger:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.confirm-dialog__btn:disabled{opacity:.65;cursor:not-allowed}.liga-banner-operador{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.liga-page{min-height:100svh;display:flex;flex-direction:column;background:var(--surface)}.liga-hero{position:relative;min-height:min(28vh,220px);display:flex;align-items:flex-end}.liga-hero__bg{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#1a2a3a;background-size:cover;background-position:center 35%;background-repeat:no-repeat}.liga-hero__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#000000e0,#00000080,#00000040);pointer-events:none}.liga-hero__inner{position:relative;z-index:2;width:100%;max-width:960px;margin:0 auto;padding:5rem 1.5rem 1.75rem}.liga-hero__back{display:inline-flex;margin-bottom:.75rem;font-size:.85rem;font-weight:500;color:#ffffffe6}.liga-hero__back:hover{color:var(--white);text-decoration:underline}.liga-hero__title{margin:0;font-size:clamp(1.75rem,5vw,2.35rem);font-weight:800;letter-spacing:-.03em;color:var(--white);text-shadow:0 2px 16px rgba(0,0,0,.5)}.liga-hero__meta{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem;margin:.65rem 0 0;font-size:.9rem;color:#ffffffe6}.liga-hero__codigo{padding:.15rem .45rem;font-size:.85rem;font-weight:700;letter-spacing:.1em;color:var(--white);background:#ffffff26;border-radius:.35rem}.liga-hero__badge{padding:.2rem .55rem;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--white);background:#0ea5e973;border-radius:var(--radius-pill)}.liga-main{flex:1;max-width:960px;margin:0 auto;padding:2rem 1.5rem 3rem;width:100%}.liga-section__title{margin:0 0 1.25rem;font-size:1.25rem;font-weight:700;color:var(--ink)}.liga-status{margin:0;color:var(--ink-muted);font-size:.95rem}.liga-empty{padding:2rem 1.5rem;text-align:center;background:var(--white);border:1px dashed #cbd5e1;border-radius:var(--radius-card);color:var(--ink-muted)}.liga-empty p{margin:0}.clasificacion-wrap{overflow-x:auto;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-soft)}.clasificacion{width:100%;border-collapse:collapse;font-size:.95rem}.clasificacion thead{background:var(--surface);border-bottom:1px solid var(--border)}.clasificacion th{padding:.85rem 1rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-muted);text-align:left}.clasificacion th:first-child{width:3.5rem;text-align:center}.clasificacion th:last-child{width:6rem;text-align:right}.clasificacion td{padding:.9rem 1rem;border-bottom:1px solid var(--border);color:var(--ink)}.clasificacion tbody tr:last-child td{border-bottom:none}.clasificacion__row--me{background:#0ea5e914}.clasificacion__row--me .clasificacion__username{font-weight:700}.clasificacion__pos{text-align:center;font-weight:700;color:var(--ink-muted)}.clasificacion__jugador{max-width:0;width:55%}.clasificacion__jugador-inner{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.clasificacion__jugador-info{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem .5rem;min-width:0}.clasificacion__username{font-weight:600;word-break:break-word}.clasificacion__admin,.clasificacion__tu{padding:.15rem .45rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius-pill)}.clasificacion__admin{color:var(--accent-dark);background:#0ea5e91f}.clasificacion__tu{color:#166534;background:#dcfce7}.clasificacion__puntos{text-align:right;font-weight:700;font-variant-numeric:tabular-nums}.clasificacion__menu{position:relative;flex-shrink:0}.clasificacion__menu-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;font-size:1.25rem;line-height:1;letter-spacing:.08em;color:var(--ink-muted);background:transparent;border:none;border-radius:.4rem;cursor:pointer;transition:background .15s,color .15s}.clasificacion__menu-btn:hover,.clasificacion__menu-btn[aria-expanded=true]{color:var(--ink);background:#0000000d}.clasificacion__menu-dropdown{position:absolute;top:calc(100% + .25rem);right:0;z-index:10;min-width:10.5rem;padding:.35rem;background:var(--white);border:1px solid var(--border);border-radius:.55rem;box-shadow:var(--shadow-soft)}.clasificacion__menu-item{display:block;width:100%;padding:.55rem .75rem;font-size:.85rem;font-weight:500;text-align:left;color:var(--ink);background:transparent;border:none;border-radius:.4rem;cursor:pointer}.clasificacion__menu-item:hover{background:var(--surface)}.clasificacion__menu-item--danger{color:#b91c1c}.clasificacion__menu-item--danger:hover{background:#fef2f2}@media (max-width: 480px){.clasificacion th,.clasificacion td{padding:.75rem .65rem}}.mis-ligas-page{min-height:100svh;display:flex;flex-direction:column;background:var(--surface)}.mis-ligas-hero{position:relative;min-height:min(28vh,220px);display:flex;align-items:flex-end}.mis-ligas-hero__bg{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#1a2a3a;background-size:cover;background-position:center 35%;background-repeat:no-repeat}.mis-ligas-hero__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#000000e0,#00000080,#00000040);pointer-events:none}.mis-ligas-hero__inner{position:relative;z-index:2;width:100%;max-width:960px;margin:0 auto;padding:5rem 1.5rem 1.75rem}.mis-ligas-hero__title{margin:0;font-size:clamp(1.75rem,5vw,2.35rem);font-weight:800;letter-spacing:-.03em;color:var(--white);text-shadow:0 2px 16px rgba(0,0,0,.5)}.mis-ligas-hero__subtitle{margin:.5rem 0 0;font-size:.95rem;color:#ffffffe6}.mis-ligas-hero__subtitle strong{font-weight:600}.mis-ligas-main{flex:1;max-width:960px;margin:0 auto;padding:2rem 1.5rem 3rem;width:100%}.mis-ligas-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1.25rem;margin-bottom:1.75rem}.mis-ligas-greeting{margin:0;color:var(--ink-muted);line-height:1.55}.mis-ligas-actions{display:flex;flex-wrap:wrap;gap:.75rem}.mis-ligas-actions__btn{min-width:unset;padding:.65rem 1.25rem;font-size:.88rem}.mis-ligas-actions__btn.is-active{box-shadow:0 0 0 3px #0ea5e959}.mis-ligas-banner{margin:0 0 1.25rem;padding:.85rem 1rem;border-radius:.65rem;font-size:.9rem;line-height:1.45}.mis-ligas-banner--ok{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.mis-ligas-banner--err{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.mis-ligas-retry{padding:.35rem .75rem;font-size:.82rem;font-weight:600;font-family:inherit;color:#991b1b;background:transparent;border:1px solid #fca5a5;border-radius:var(--radius-pill);cursor:pointer}.mis-ligas-retry:hover{background:#fff}.mis-ligas-panel{margin-bottom:1.75rem;padding:1.35rem 1.25rem;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-soft)}.mis-ligas-panel__title{margin:0 0 .5rem;font-size:1.1rem;font-weight:700;color:var(--ink)}.mis-ligas-panel__hint{margin:0 0 1rem;font-size:.9rem;color:var(--ink-muted)}.mis-ligas-form{max-width:360px}.mis-ligas-form .btn{width:auto;min-width:10rem}.mis-ligas-codigo-input{font-family:ui-monospace,Consolas,monospace;letter-spacing:.12em;text-transform:uppercase}.mis-ligas-list-section{margin-top:.5rem}.mis-ligas-list__heading{margin:0 0 1rem;font-size:1.15rem;font-weight:700;color:var(--ink)}.mis-ligas-status{margin:0;color:var(--ink-muted);font-size:.95rem}.mis-ligas-empty{padding:2rem 1.5rem;text-align:center;background:var(--white);border:1px dashed #cbd5e1;border-radius:var(--radius-card);color:var(--ink-muted)}.mis-ligas-empty p{margin:0 0 .5rem}.mis-ligas-empty p:last-child{margin-bottom:0}.mis-ligas-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.liga-card{display:flex;flex-direction:column;padding:1.25rem 1.2rem;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-soft);transition:transform .15s ease,box-shadow .15s ease}.liga-card:has(.liga-card__body:hover),.liga-card:has(.liga-card__footer a:hover){transform:translateY(-2px);box-shadow:0 20px 40px #0a16281a}.liga-card__body{display:block;color:inherit;text-decoration:none}.liga-card__footer{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-top:1rem;padding-top:.85rem;border-top:1px solid var(--border)}.liga-card__delete{padding:.35rem .7rem;font-size:.78rem;font-weight:600;font-family:inherit;color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:.45rem;cursor:pointer;white-space:nowrap;transition:color .15s ease,border-color .15s ease,background .15s ease}.liga-card__delete:hover{color:#991b1b;border-color:#fca5a5;background:#fee2e2}.liga-card__cta{font-size:.82rem;font-weight:600;color:var(--accent-dark);text-decoration:none}.liga-card__cta:hover{text-decoration:underline}.liga-card__top{display:flex;align-items:center;justify-content:space-between;gap:.65rem;margin-bottom:.75rem}.liga-card__nombre{margin:0;flex:1;min-width:0;font-size:1.05rem;font-weight:700;color:var(--ink);line-height:1.3}.liga-card__body:hover .liga-card__nombre{color:var(--accent-dark)}.liga-card__badge{flex-shrink:0;padding:.2rem .55rem;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--accent-dark);background:#0ea5e91f;border-radius:var(--radius-pill)}.liga-card__meta{margin:0;display:flex;flex-direction:column;gap:.65rem}.liga-card__row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.liga-card__row dt{margin:0;font-size:.78rem;font-weight:600;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.04em}.liga-card__row dd{margin:0;font-size:.95rem;font-weight:600;color:var(--ink)}.liga-card__codigo{padding:.2rem .5rem;font-size:.88rem;font-weight:700;letter-spacing:.1em;color:var(--ink);background:var(--surface);border-radius:.35rem}.mis-ligas-back{margin-top:1.5rem}@media (max-width: 560px){.mis-ligas-header{flex-direction:column}.mis-ligas-actions{width:100%}.mis-ligas-actions__btn{flex:1}}.operador-ligas-page{min-height:100svh;display:flex;flex-direction:column;background:var(--surface)}.operador-ligas-hero{position:relative;min-height:min(26vh,200px);display:flex;align-items:flex-end}.operador-ligas-hero__bg{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#1a2a3a;background-size:cover;background-position:center 35%;background-repeat:no-repeat}.operador-ligas-hero__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#000000e0,#00000080,#00000040);pointer-events:none}.operador-ligas-hero__inner{position:relative;z-index:2;width:100%;max-width:960px;margin:0 auto;padding:5rem 1.5rem 1.75rem}.operador-ligas-hero__title{margin:0;font-size:clamp(1.75rem,5vw,2.2rem);font-weight:800;letter-spacing:-.03em;color:var(--white);text-shadow:0 2px 16px rgba(0,0,0,.5)}.operador-ligas-hero__subtitle{margin:.5rem 0 0;font-size:.95rem;color:#ffffffe6}.operador-ligas-main{flex:1;max-width:960px;margin:0 auto;padding:2rem 1.5rem 3rem;width:100%}.liga-card__badge--readonly{color:#92400e;background:#fef3c7}.operador-ligas-back{margin-top:1.5rem}.operador-page{min-height:100svh;display:flex;flex-direction:column;background:var(--surface)}.operador-hero{position:relative;min-height:min(26vh,200px);display:flex;align-items:flex-end}.operador-hero__bg{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#1a2a3a;background-size:cover;background-position:center 35%;background-repeat:no-repeat}.operador-hero__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#000000e0,#00000080,#00000040);pointer-events:none}.operador-hero__inner{position:relative;z-index:2;width:100%;max-width:720px;margin:0 auto;padding:5rem 1.5rem 1.75rem}.operador-hero__title{margin:0;font-size:clamp(1.75rem,5vw,2.2rem);font-weight:800;letter-spacing:-.03em;color:var(--white);text-shadow:0 2px 16px rgba(0,0,0,.5)}.operador-hero__subtitle{margin:.5rem 0 0;font-size:.95rem;color:#ffffffe6}.operador-main{flex:1;max-width:720px;margin:0 auto;padding:2rem 1.5rem 3rem;width:100%}.operador-banner{margin:0 0 1.25rem;padding:.85rem 1rem;border-radius:.65rem;font-size:.9rem;line-height:1.45}.operador-banner--ok{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.operador-banner--err{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.operador-retry{padding:.35rem .75rem;font-size:.82rem;font-weight:600;font-family:inherit;color:#991b1b;background:transparent;border:1px solid #fca5a5;border-radius:var(--radius-pill);cursor:pointer}.operador-panel{margin-bottom:1.75rem;padding:1.35rem 1.25rem;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-soft)}.operador-panel__title{margin:0 0 1rem;font-size:1.1rem;font-weight:700;color:var(--ink)}.operador-form__row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.operador-form__row--scores{max-width:16rem}.operador-form__submit{width:auto;min-width:10rem}.operador-list__heading{margin:0 0 1rem;font-size:1.15rem;font-weight:700;color:var(--ink)}.operador-status{margin:0;color:var(--ink-muted)}.operador-empty{padding:2rem 1.5rem;text-align:center;background:var(--white);border:1px dashed #cbd5e1;border-radius:var(--radius-card);color:var(--ink-muted)}.operador-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.85rem}.operador-card{padding:1.15rem 1.2rem;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-soft)}.operador-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.operador-card__teams{margin:0;font-size:1rem;font-weight:700;color:var(--ink);line-height:1.35}.operador-card__vs{margin:0 .35rem;font-weight:500;color:var(--ink-muted)}.operador-card__estado{flex-shrink:0;padding:.2rem .55rem;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius-pill)}.operador-card__estado--pend{color:#92400e;background:#fef3c7}.operador-card__estado--live{color:#991b1b;background:#fee2e2;animation:operador-live-pulse 2s ease-in-out infinite}@keyframes operador-live-pulse{0%,to{opacity:1}50%{opacity:.75}}.operador-card__estado--fin{color:#166534;background:#dcfce7}.operador-card__live-hint{margin:0 0 .85rem;font-size:.82rem;color:var(--ink-muted);line-height:1.45}.operador-card__auto-hint{margin:.75rem 0 0;font-size:.8rem;color:var(--ink-muted);line-height:1.4}.operador-card__btn--danger{color:#991b1b;border-color:#fecaca}.operador-card__btn--danger:hover:not(:disabled){background:#fef2f2}.operador-card__fecha{margin:.5rem 0 0;font-size:.88rem;color:var(--ink-muted)}.operador-card__marcador{margin:.35rem 0 0;font-size:.92rem;font-weight:600;color:var(--ink)}.operador-card__actions{display:flex;flex-wrap:wrap;gap:.65rem;margin-top:1rem}.operador-card__btn{min-width:unset;padding:.5rem 1rem;font-size:.85rem}.operador-card__finalize-title{margin:0 0 .75rem;font-size:.95rem;font-weight:600;color:var(--ink)}.operador-back{margin-top:1.5rem}@media (max-width: 560px){.operador-form__row{grid-template-columns:1fr}}.profile-page{min-height:100svh;display:flex;flex-direction:column;background:var(--surface)}.profile-hero{position:relative;min-height:min(26vh,200px);display:flex;align-items:flex-end}.profile-hero__bg{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#1a2a3a;background-size:cover;background-position:center 35%;background-repeat:no-repeat}.profile-hero__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#000000e0,#00000080,#00000040);pointer-events:none}.profile-hero__inner{position:relative;z-index:2;width:100%;max-width:560px;margin:0 auto;padding:5rem 1.5rem 1.75rem}.profile-hero__title{margin:0;font-size:clamp(1.75rem,5vw,2.2rem);font-weight:800;letter-spacing:-.03em;color:var(--white);text-shadow:0 2px 16px rgba(0,0,0,.5)}.profile-hero__subtitle{margin:.5rem 0 0;font-size:.95rem;color:#ffffffe6}.profile-main{flex:1;max-width:560px;margin:0 auto;padding:2rem 1.5rem 3rem;width:100%}.profile-status{margin:0;color:var(--ink-muted)}.profile-banner{margin:0 0 1.25rem;padding:.85rem 1rem;border-radius:.65rem;font-size:.9rem;line-height:1.45}.profile-banner--ok{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.profile-banner--err{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.profile-retry{padding:.35rem .75rem;font-size:.82rem;font-weight:600;font-family:inherit;color:#991b1b;background:transparent;border:1px solid #fca5a5;border-radius:var(--radius-pill);cursor:pointer}.profile-panel{padding:1.35rem 1.25rem;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-soft)}.profile-panel__header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1.25rem}.profile-panel__title{margin:0 0 1rem;font-size:1.1rem;font-weight:700;color:var(--ink)}.profile-panel__header .profile-panel__title{margin-bottom:0}.profile-edit-btn{min-width:unset;padding:.5rem 1rem;font-size:.85rem}.profile-details{margin:0;display:flex;flex-direction:column;gap:1rem}.profile-details__row{display:flex;flex-direction:column;gap:.25rem}.profile-details__row dt{margin:0;font-size:.78rem;font-weight:600;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.04em}.profile-details__row dd{margin:0;font-size:1rem;font-weight:600;color:var(--ink)}.profile-form{max-width:100%}.profile-form__actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.25rem}.profile-form__actions .btn{width:auto;min-width:8rem}.profile-back{margin-top:1.5rem}@media (max-width: 480px){.profile-form__actions .btn{flex:1;min-width:unset}}
