/* Archivo: /porra/assets/css/style.css · Versión 1.0.13 */
:root{--bg:#f4f1ec;--card:#fff;--ink:#171717;--muted:#6b625b;--brand:#111;--accent:#d9a441;--danger:#b3261e;--ok:#137333;--line:#e7dfd4;--shadow:0 12px 30px rgba(0,0,0,.08);--radius:20px}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--ink)}a{color:inherit}.site-wrap{max-width:980px;margin:0 auto;padding:18px}.hero{background:linear-gradient(135deg,#171717,#35302a);color:white;border-radius:28px;padding:32px;box-shadow:var(--shadow);margin-bottom:18px}.hero h1{font-size:clamp(32px,6vw,62px);line-height:1;margin:5px 0}.hero p{font-size:20px;margin:0;color:#eee}.kicker,.small-label{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-size:13px;font-weight:800}.card,.match-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;margin:18px 0}.match-card{display:grid;grid-template-columns:1fr 260px;gap:20px;align-items:stretch}.match-card h2{font-size:38px;margin:0 0 8px}.big-date{font-size:22px;font-weight:700}.sponsor-box{display:flex;gap:18px;align-items:center;background:#fbf8f1;border:1px solid var(--line);border-radius:18px;padding:16px;margin-top:18px}.sponsor-box img{max-width:110px;max-height:80px;object-fit:contain;background:white;border-radius:12px;padding:8px}.match-score{background:#111;color:white;border-radius:18px;padding:20px;display:flex;flex-direction:column;justify-content:center;gap:10px}.match-score span{color:#bbb}.score-line{font-size:28px;font-weight:900}.grid{display:grid;gap:16px}.grid.two{grid-template-columns:repeat(2,1fr)}.grid.three{grid-template-columns:repeat(3,1fr)}.grid.four{grid-template-columns:repeat(4,1fr)}label{display:block;font-weight:800;margin-bottom:14px}input,select,textarea{width:100%;padding:14px 15px;border:1px solid #d8d0c6;border-radius:14px;font:inherit;margin-top:7px;background:#fff}textarea{resize:vertical}.hint,.muted{color:var(--muted);font-size:14px}.question-block{border:1px solid var(--line);background:#fdfbf8;border-radius:18px;padding:18px;margin:18px 0}.question-block h3{margin:0 0 6px}.score-inputs{display:flex;align-items:end;gap:14px}.score-inputs input{font-size:30px;font-weight:900;text-align:center}.score-inputs span{font-size:38px;font-weight:900;padding-bottom:6px}.check{font-weight:600;display:flex;gap:10px;align-items:flex-start}.check input{width:auto;margin-top:3px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--brand);color:#fff;border:0;border-radius:999px;padding:13px 22px;text-decoration:none;font-weight:900;cursor:pointer}.btn-large{font-size:20px;width:100%;padding:18px}.btn-outline{background:transparent;color:var(--brand);border:1px solid var(--brand)}.actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.center-card{text-align:center}.big-ok{font-size:70px;color:var(--ok);font-weight:900}.participation-number{font-size:46px;font-weight:900;background:#111;color:white;border-radius:18px;padding:16px;display:inline-block;letter-spacing:.08em}.alert{padding:14px 16px;border-radius:14px;margin:14px 0}.alert-success{background:#e7f4ea;color:#0b5c22}.alert-danger{background:#fce8e6;color:#9b1c16}.alert-warning{background:#fff3cd;color:#664d03}.stats-grid,.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}.stats-grid div,.metric{background:#fbf8f1;border:1px solid var(--line);border-radius:18px;padding:18px}.stats-grid strong,.metric strong{display:block;font-size:28px;line-height:1.1}.stats-grid span,.metric span{color:var(--muted);font-weight:700}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}th{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.badge{display:inline-block;padding:5px 9px;border-radius:99px;font-size:12px;font-weight:900;text-transform:uppercase}.badge-success{background:#e7f4ea;color:#137333}.badge-warning{background:#fff3cd;color:#664d03}.badge-danger{background:#fce8e6;color:#b3261e}.badge-muted{background:#eee;color:#555}.footer{display:flex;justify-content:space-between;color:var(--muted);font-size:13px;padding:24px 4px}.hidden{display:none!important}.login-body{min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:min(440px,100%);background:white;border-radius:26px;padding:28px;box-shadow:var(--shadow)}.admin-layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:#111;color:white;padding:22px;position:sticky;top:0;height:100vh}.brand{font-size:24px;line-height:1.05;margin-bottom:24px}.sidebar nav{display:grid;gap:8px}.sidebar a{color:white;text-decoration:none;padding:11px 12px;border-radius:12px;background:rgba(255,255,255,.07)}.sidebar a:hover{background:rgba(255,255,255,.14)}.version{margin-top:20px;color:#bbb;font-size:12px}.admin-main{padding:24px;min-width:0}.admin-top,.section-head{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:16px}.admin-top h1{margin:0;font-size:34px}.admin-form .btn{margin-top:10px}.winner-name{font-size:44px;font-weight:950;line-height:1}.winner-points{font-size:28px;font-weight:900;color:var(--accent)}.score-public{font-size:22px;font-weight:900;background:#111;color:#fff;border-radius:16px;padding:14px;margin:15px 0}@media(max-width:780px){.match-card,.grid.two,.grid.three,.grid.four,.admin-layout{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.admin-top,.section-head{align-items:flex-start;flex-direction:column}.hero{padding:24px}.match-card h2{font-size:30px}.score-inputs{gap:8px}.site-wrap,.admin-main{padding:12px}}


.member-callout{margin:24px auto;padding:18px;border-radius:18px;background:#fff7df;border:1px solid #ead28a;max-width:720px;text-align:center}
.member-callout h3{margin:0 0 8px 0}
.member-callout p{margin:0 0 14px 0;color:#4f4228}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.6 */
.sponsors-accordion{display:grid;gap:12px;margin:14px 0 22px}
.sponsor-accordion-item{border:1px solid var(--line);border-radius:18px;background:#fdfbf8;overflow:hidden}
.sponsor-accordion-item summary{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px;cursor:pointer;font-weight:900;list-style:none}
.sponsor-accordion-item summary::-webkit-details-marker{display:none}
.sponsor-accordion-item summary:before{content:'+';display:inline-grid;place-items:center;flex:0 0 30px;width:30px;height:30px;border-radius:999px;background:#111;color:#fff;font-weight:950}
.sponsor-accordion-item[open] summary:before{content:'−'}
.sponsor-summary-title{flex:1;font-size:17px}
.sponsor-summary-prize{font-size:13px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:6px 10px;white-space:nowrap}
.sponsor-accordion-content{border-top:1px solid var(--line);padding:18px;background:#fff}
@media(max-width:780px){.sponsor-accordion-item summary{align-items:flex-start;flex-wrap:wrap}.sponsor-summary-prize{white-space:normal}}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.7 */
.btn-small{padding:8px 13px;font-size:13px}
.compact-table{font-size:13px;table-layout:auto}
.compact-table th,.compact-table td{padding:7px 8px;line-height:1.25;vertical-align:top}
.compact-table th{font-size:11px;letter-spacing:.04em;white-space:nowrap}
.compact-table .badge{font-size:10px;padding:4px 7px}
.participaciones-table td:nth-child(1){width:58px;white-space:nowrap}
.participaciones-table td:nth-child(2){width:110px}
.participaciones-table td:nth-child(3){min-width:180px;max-width:260px}
.participaciones-table td:nth-child(4){min-width:190px;max-width:280px}
.participaciones-table td:nth-child(5){max-width:120px}
.participaciones-table td:nth-child(6){width:132px;font-size:12px;color:var(--muted)}
.cell-muted{display:block;color:var(--muted);font-size:12px;font-weight:600;margin-top:3px}
.email-break{word-break:break-all}
.log-message-cell{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:12px;white-space:normal;word-break:break-word;max-width:520px}
@media(max-width:900px){.compact-table{font-size:12px}.compact-table th,.compact-table td{padding:6px}.participaciones-table td:nth-child(6){white-space:normal}}


/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.8 */
.participaciones-admin-table td:nth-child(1){width:54px;white-space:nowrap}
.participaciones-admin-table td:nth-child(2){width:96px}
.participaciones-admin-table td:nth-child(3){min-width:120px;max-width:180px}
.participaciones-admin-table td:nth-child(4){width:118px;white-space:nowrap}
.participaciones-admin-table td:nth-child(5){min-width:160px;max-width:220px}
.participaciones-admin-table td:nth-child(6){max-width:95px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.participaciones-admin-table td:nth-child(7){width:112px;font-size:11px;color:var(--muted)}
.participaciones-admin-table td:nth-child(8){width:94px;text-align:right}
.contact-icons{display:flex;align-items:center;gap:6px;flex-wrap:nowrap}
.icon-link{display:inline-grid;place-items:center;width:31px;height:31px;border-radius:999px;background:#111;color:#fff;text-decoration:none;font-size:15px;font-weight:950;line-height:1}
.icon-link:hover{transform:translateY(-1px);box-shadow:0 6px 12px rgba(0,0,0,.12)}
.icon-link.whatsapp{background:#128c3c;color:#fff}
.btn-danger{background:var(--danger);color:#fff}
.admin-modal{border:0;border-radius:24px;padding:0;width:min(860px,calc(100vw - 24px));box-shadow:0 30px 80px rgba(0,0,0,.35);background:#fff;color:var(--ink)}
.admin-modal::backdrop{background:rgba(0,0,0,.55)}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px 24px;border-bottom:1px solid var(--line);background:#fdfbf8}
.modal-head h3{margin:4px 0 0;font-size:28px;line-height:1.05}
.modal-close{border:0;background:#111;color:#fff;width:38px;height:38px;border-radius:999px;font-size:24px;line-height:1;cursor:pointer}
.modal-contact-row{display:flex;gap:10px;flex-wrap:wrap;padding:18px 24px 0}
.modal-form{padding:6px 24px 18px}
.modal-actions{display:flex;justify-content:flex-end;margin-top:8px}
.modal-danger-zone{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;border-top:1px solid var(--line);padding:18px 24px;background:#fff7f5;border-radius:0 0 24px 24px}
.modal-danger-zone form{margin:0}
@media(max-width:900px){.participaciones-admin-table td:nth-child(6),.participaciones-admin-table th:nth-child(6){display:none}.participaciones-admin-table td:nth-child(7),.participaciones-admin-table th:nth-child(7){display:none}.icon-link{width:29px;height:29px}.admin-modal{width:calc(100vw - 14px)}.modal-head,.modal-contact-row,.modal-form,.modal-danger-zone{padding-left:16px;padding-right:16px}}


/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.10
   Ajuste visual: tipografía más ligera y lectura menos agresiva. */
:root{--shadow:0 10px 24px rgba(0,0,0,.065)}
body{font-family:"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;font-weight:400;letter-spacing:0;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}
.hero h1{font-weight:700;letter-spacing:-.035em}
.hero p{font-weight:400}
.kicker,.small-label{font-weight:650;letter-spacing:.09em}
.match-card h2,.admin-top h1,.modal-head h3{font-weight:700;letter-spacing:-.025em}
label{font-weight:650}
.btn{font-weight:700;letter-spacing:0}
.btn-large{font-weight:700}
.big-date,.score-line,.score-inputs input,.score-inputs span,.winner-name,.winner-points,.participation-number,.big-ok{font-weight:700}
.stats-grid strong,.metric strong{font-weight:700}
.stats-grid span,.metric span{font-weight:600}
th{font-weight:650;letter-spacing:.045em}
.badge{font-weight:650;letter-spacing:.02em}
.brand{font-weight:500}.brand strong{font-weight:700}
.sidebar a{font-weight:500}.sidebar a:hover{background:rgba(255,255,255,.12)}
.sponsor-accordion-item summary{font-weight:650}.sponsor-accordion-item summary:before{font-weight:700}
.icon-link{font-weight:700}
.score-inputs input{font-size:28px}.score-inputs span{font-size:34px}.participation-number{font-size:38px}.winner-name{font-size:38px}
.footer{font-weight:400}.footer strong{font-weight:650}
@media(max-width:780px){.hero h1{font-size:clamp(29px,9vw,44px)}.winner-name{font-size:32px}.participation-number{font-size:32px}}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.11
   Corrección menú admin: lateral fijo, visible completo y con scroll interno. */
@media(min-width:781px){
  .admin-layout{
    display:block;
    min-height:100vh;
  }
  .sidebar{
    position:fixed;
    left:0;
    top:0;
    bottom:0;
    width:270px;
    height:auto;
    max-height:100vh;
    overflow-y:auto;
    overflow-x:hidden;
    z-index:50;
    padding:18px 16px 26px;
    scrollbar-width:thin;
    scrollbar-color:rgba(255,255,255,.35) rgba(255,255,255,.08);
  }
  .sidebar::-webkit-scrollbar{width:8px}
  .sidebar::-webkit-scrollbar-track{background:rgba(255,255,255,.08);border-radius:999px}
  .sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.35);border-radius:999px}
  .brand{
    font-size:20px;
    margin-bottom:16px;
  }
  .sidebar nav{
    gap:7px;
  }
  .sidebar a{
    min-height:42px;
    display:flex;
    align-items:center;
    padding:9px 12px;
    line-height:1.2;
  }
  .version{
    margin-top:14px;
    padding-bottom:8px;
  }
  .admin-main{
    margin-left:270px;
    padding:24px 28px;
    min-width:0;
  }
}
@media(max-width:780px){
  .admin-layout{
    display:grid;
    grid-template-columns:1fr;
  }
  .sidebar{
    position:relative;
    width:auto;
    height:auto;
    max-height:none;
    overflow:visible;
  }
  .admin-main{
    margin-left:0;
  }
}


/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.12
   Afinado visual: menos trazo, botones más ligeros y lectura administrativa más cómoda. */
body{font-weight:400;color:#202020}
h1,h2,h3,h4,.admin-top h1,.match-card h2,.modal-head h3{font-weight:600;letter-spacing:-.018em}
h2{font-size:26px} h3{font-size:20px}
label{font-weight:500;color:#3a342f;margin-bottom:12px}
input,select,textarea{font-weight:400;border-radius:12px;padding:12px 13px;border-color:#ddd5cc}
.hint,.muted{font-weight:400;color:#756d66}
.kicker,.small-label,th{font-weight:550;letter-spacing:.035em}
.btn{font-weight:550;padding:11px 18px;border-radius:16px;box-shadow:none;min-height:42px;line-height:1.15;text-shadow:none}
.btn:hover{filter:brightness(.96)}
.btn-large{font-size:18px;font-weight:550;padding:15px 18px}
.btn-small{font-weight:500;padding:7px 11px;border-radius:12px}
.btn-outline{border-color:#777;background:#fff;color:#222}
.badge{font-weight:550;text-transform:none;letter-spacing:0;border-radius:10px}
.card,.match-card{box-shadow:0 8px 20px rgba(0,0,0,.045)}
.sidebar{font-weight:400}.sidebar a{font-weight:400;background:rgba(255,255,255,.075)}.sidebar a:hover{background:rgba(255,255,255,.13)}
.brand{font-weight:400}.brand strong{font-weight:600}
.version{font-weight:400;color:#c9c9c9}
.admin-top h1{font-size:30px}.admin-main{font-size:15.5px}
.table-wrap table{font-size:15px}th{font-size:12px;color:#6f6861}td{font-weight:400}
.score-line,.winner-name,.winner-points,.participation-number,.big-ok,.stats-grid strong,.metric strong{font-weight:650}
.score-inputs input,.score-inputs span{font-weight:600}.score-inputs input{font-size:26px}.score-inputs span{font-size:30px}
.sponsor-accordion-item summary{font-weight:500}.sponsor-accordion-item summary:before{font-weight:500;background:#252525}
.icon-link{font-weight:500;box-shadow:none}
.mail-ready-box{margin:12px 0 16px;padding:13px 15px;border:1px solid #e0d2ab;background:#fff8df;border-radius:14px;color:#3f3420;font-size:14px;font-weight:400}
.mail-ready-box strong{font-weight:600}.mail-ready-box code{font-weight:500;background:rgba(255,255,255,.65);padding:2px 5px;border-radius:6px}
@media(min-width:781px){.sidebar a{min-height:39px;padding:8px 11px}.brand{font-size:19px}.admin-main{padding:22px 26px}}
@media(max-width:780px){.btn{width:auto}.admin-top h1{font-size:26px}h2{font-size:23px}}


/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.13
   Tipografía más fina y botones menos pesados. */
:root{
  --brand:#2a2a2a;
  --ink:#222222;
  --shadow:0 6px 18px rgba(0,0,0,.045);
}
body{
  font-family:Arial,"Helvetica Neue",Helvetica,sans-serif !important;
  font-weight:400 !important;
  color:#222;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
h1,h2,h3,h4,.hero h1,.admin-top h1,.match-card h2,.modal-head h3{
  font-family:Arial,"Helvetica Neue",Helvetica,sans-serif !important;
  font-weight:500 !important;
  letter-spacing:-.012em !important;
}
h2{font-size:25px} h3{font-size:19px}
strong,b{font-weight:600 !important}
label,.check{font-weight:400 !important;color:#3f3a36}
.kicker,.small-label,th,.badge{font-weight:500 !important;letter-spacing:.025em !important}
.hint,.muted,.footer,.version,td,p,li{font-weight:400 !important}
input,select,textarea{
  font-family:Arial,"Helvetica Neue",Helvetica,sans-serif !important;
  font-weight:400 !important;
  font-size:15px;
  border-radius:10px;
  padding:11px 12px;
}
.btn,.button,button.btn,a.btn{
  font-family:Arial,"Helvetica Neue",Helvetica,sans-serif !important;
  font-weight:400 !important;
  letter-spacing:0 !important;
  background:#2b2b2b;
  color:#fff;
  border-radius:12px;
  padding:10px 16px;
  min-height:39px;
  box-shadow:none !important;
  text-shadow:none !important;
}
.btn:hover{filter:none;background:#111}
.btn-large{font-size:17px !important;font-weight:400 !important;padding:14px 17px}
.btn-small{font-size:13px !important;font-weight:400 !important;padding:7px 10px;min-height:34px;border-radius:10px}
.btn-outline{background:#fff !important;color:#222 !important;border:1px solid #b8b0a6 !important}
.btn-outline:hover{background:#f6f2ec !important}
.btn-danger{background:#9f261f !important;color:#fff !important}
.sidebar a{font-weight:400 !important;background:rgba(255,255,255,.06)}
.brand,.brand strong{font-weight:500 !important}
.card,.match-card{box-shadow:0 6px 18px rgba(0,0,0,.04)}
.stats-grid strong,.metric strong,.score-line,.winner-name,.winner-points,.participation-number,.big-ok,.score-inputs input,.score-inputs span{font-weight:500 !important}
.icon-link{font-weight:400 !important;background:#2b2b2b;box-shadow:none !important}
.sponsor-accordion-item summary,.sponsor-accordion-item summary:before{font-weight:400 !important}
.section-head-compact{align-items:flex-start;margin-bottom:14px}
.inline-form{margin:0;display:flex;align-items:flex-start;gap:8px;flex-shrink:0}
.log-message-cell{font-weight:400 !important}
@media(max-width:780px){
  .section-head-compact{flex-direction:column}
  .inline-form{width:100%}
}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.14
   Logo público, emails y página de estado de porra en marcha. */
.top-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin:0 0 14px}
.btn-gold{background:#d9a441 !important;color:#111 !important;border:1px solid #c7922c !important}
.hero-with-logo{display:grid;grid-template-columns:210px 1fr;gap:24px;align-items:center;background:linear-gradient(135deg,#ffffff,#f7f2ea);color:#171717;border:1px solid var(--line)}
.public-logo-link{display:block;line-height:0;text-decoration:none}
.public-logo-link img{display:block;width:100%;max-width:210px;height:auto;border-radius:28px;box-shadow:0 10px 24px rgba(0,0,0,.06);background:#fff}
.hero-with-logo .kicker{color:#b68422}.hero-with-logo p{color:#5d554d}.hero-copy{min-width:0}
.admin-brand-logo{display:block;background:transparent !important;padding:0 !important;margin:0 0 12px !important;text-align:center}
.admin-brand-logo img{width:118px;max-width:100%;height:auto;border-radius:18px;background:#fff;display:block;margin:0 auto}
.btn-light-score{margin-top:10px;background:#fff !important;color:#111 !important;border:0 !important;width:100%;font-size:14px}
.estado-publico-card{overflow:hidden}
.estado-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:18px}
.estado-head h2{margin:4px 0 8px;font-size:34px}
.estado-live-badge{background:#171717;color:#fff;border-radius:999px;padding:10px 15px;text-transform:capitalize;white-space:nowrap;font-size:14px}
.estado-scoreboard{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:14px;background:#171717;color:#fff;border-radius:24px;padding:20px;margin:18px 0}
.team-score{display:grid;gap:4px;text-align:center}.team-score span{color:#d8d8d8;font-size:15px}.team-score strong{font-size:clamp(46px,10vw,86px);line-height:.95;font-weight:500 !important}.score-separator{font-size:clamp(42px,8vw,70px);color:#d9a441;line-height:1}
.estado-meta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:18px 0}.estado-meta-grid .metric{margin:0}.estado-meta-grid .metric strong{font-size:24px}
.estado-sponsors{margin-top:16px}.estado-actions{margin-top:18px;justify-content:flex-start}.estado-ranking-table td:nth-child(1){width:52px}.estado-ranking-table td:nth-child(3){width:90px;text-align:center}
@media(max-width:780px){.top-actions{justify-content:stretch}.top-actions .btn{flex:1 1 auto}.hero-with-logo{grid-template-columns:1fr;text-align:center}.public-logo-link img{max-width:230px;margin:0 auto}.estado-head{display:block}.estado-live-badge{display:inline-block;margin-top:8px}.estado-meta-grid{grid-template-columns:1fr 1fr}.estado-scoreboard{padding:16px}.estado-actions{justify-content:center}.estado-ranking-table td:nth-child(4),.estado-ranking-table th:nth-child(4){display:none}}
@media(max-width:520px){.estado-meta-grid{grid-template-columns:1fr}.team-score strong{font-size:54px}}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.15
   Logo más contenido, favicon/webapp listos y mejor proporción visual. */
.hero-with-logo{grid-template-columns:140px 1fr;gap:20px;padding:24px 26px}
.public-logo-link img{width:100%;max-width:140px;max-height:140px;object-fit:contain;border-radius:0;box-shadow:none;background:transparent}
.hero-copy h1{margin-top:2px}
.hero-copy p{font-size:18px}
.admin-brand-logo{margin:0 0 10px !important}
.admin-brand-logo img{width:84px;max-width:84px;max-height:84px;object-fit:contain;border-radius:0;background:transparent;box-shadow:none}
.sidebar .brand{font-size:18px;margin-bottom:14px;text-align:center}
.sidebar .brand strong{display:block}
@media(max-width:780px){
  .hero-with-logo{grid-template-columns:1fr;gap:14px;padding:20px 18px}
  .public-logo-link img{max-width:120px;max-height:120px}
}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.16
   Tipografía con más estilo, parecida al enfoque limpio de InfoCheckin. */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;450;500;600;700;800&family=Manrope:wght@400;500;600;700;800&display=swap');
:root{
  --font-ui:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  --font-display:"Manrope","Inter",system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
}
body,
input,
select,
textarea,
button,
.btn,
.sidebar a,
table,
.card,
.match-card{
  font-family:var(--font-ui) !important;
  font-weight:400 !important;
  letter-spacing:-.006em;
}
h1,h2,h3,h4,
.hero h1,
.admin-top h1,
.match-card h2,
.estado-head h2,
.modal-head h3,
.brand,
.score-line,
.winner-name,
.participation-number{
  font-family:var(--font-display) !important;
  font-weight:700 !important;
  letter-spacing:-.035em !important;
}
.hero h1{font-weight:800 !important;letter-spacing:-.045em !important}
.admin-top h1{font-weight:650 !important;font-size:31px;letter-spacing:-.035em !important}
h2{font-weight:650 !important;letter-spacing:-.03em !important}
h3{font-weight:600 !important;letter-spacing:-.025em !important}
.kicker,.small-label,th{
  font-family:var(--font-ui) !important;
  font-weight:650 !important;
  letter-spacing:.06em !important;
}
label{font-family:var(--font-ui) !important;font-weight:500 !important;letter-spacing:-.01em}
strong,b{font-weight:650 !important}
.btn,.button,button.btn,a.btn{
  font-family:var(--font-ui) !important;
  font-weight:600 !important;
  letter-spacing:-.01em !important;
  border-radius:14px;
}
.btn-large{font-weight:650 !important}
.sidebar a{font-weight:500 !important;letter-spacing:-.012em}
.brand{font-weight:600 !important}.brand strong{font-weight:800 !important}
.metric strong,.stats-grid strong,.team-score strong,.score-inputs input,.score-inputs span{font-family:var(--font-display) !important;font-weight:700 !important;letter-spacing:-.035em !important}
.badge{font-weight:600 !important;font-family:var(--font-ui) !important}
.footer,.hint,.muted,p,li,td{font-family:var(--font-ui) !important;letter-spacing:-.006em}


/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.17
   Explicación clara de puntos al votar y aviso de actualización pública cada 20 segundos. */
.scoring-help{
  margin:14px 0 22px;
  padding:18px;
  border:1px solid rgba(217,164,65,.38);
  border-radius:18px;
  background:linear-gradient(135deg,#fffaf0,#ffffff);
}
.scoring-help-head{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  margin-bottom:14px;
}
.scoring-help-head h3{
  margin:3px 0 0;
  font-size:22px;
}
.scoring-help-head > strong{
  flex:0 0 auto;
  padding:8px 11px;
  border-radius:999px;
  background:#171717;
  color:#fff;
  font-size:13px;
  font-weight:650 !important;
  white-space:nowrap;
}
.scoring-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin-bottom:12px;
}
.scoring-grid div{
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  padding:12px;
}
.scoring-grid strong{
  display:block;
  font-size:24px;
  line-height:1;
  color:#b68422;
  margin-bottom:5px;
}
.scoring-grid span{
  display:block;
  font-size:13px;
  color:#554d45;
}
@media(max-width:780px){
  .scoring-help{padding:15px}
  .scoring-help-head{display:block}
  .scoring-help-head > strong{display:inline-block;margin-top:10px;white-space:normal}
  .scoring-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:520px){.scoring-grid{grid-template-columns:1fr}}


/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.18
   Puntuación visual, condiciones de participación, privacidad pública y footer con logo. */
.scoring-help-visual{border:0;background:linear-gradient(135deg,#171717,#2b241b);color:#fff;box-shadow:0 18px 42px rgba(0,0,0,.16);overflow:hidden}
.scoring-help-visual .small-label{color:#d9a441}.scoring-help-visual h3{margin:4px 0 0;color:#fff;font-size:clamp(24px,4vw,34px)}.scoring-help-visual .scoring-help-head{border:0;margin-bottom:18px}.scoring-help-visual .scoring-help-head strong{background:rgba(217,164,65,.16);color:#f3d38a;border:1px solid rgba(217,164,65,.36);border-radius:999px;padding:9px 13px;font-size:13px;white-space:nowrap}
.scoring-feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.scoring-feature-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);border-radius:18px;padding:16px;display:grid;gap:5px;min-height:142px}.scoring-feature-card .score-icon{font-size:24px;line-height:1}.scoring-feature-card strong{font-family:Manrope,Inter,system-ui,sans-serif;font-size:30px;line-height:1;color:#f1c46b}.scoring-feature-card span{font-weight:750;color:#fff}.scoring-feature-card small{color:#d8d1c7;line-height:1.3}.scoring-main-card{background:linear-gradient(135deg,rgba(217,164,65,.28),rgba(255,255,255,.08));border-color:rgba(217,164,65,.45)}.scoring-rules-note{margin-top:14px;padding:14px 16px;border-radius:16px;background:rgba(255,255,255,.08);color:#efe9df;border:1px solid rgba(255,255,255,.12)}
.participation-conditions{margin:18px 0;padding:18px;border:1px solid #ead8a8;background:#fff8e7;border-radius:18px}.participation-conditions h3{margin:0 0 8px}.participation-conditions p{margin:7px 0;color:#4f4436}.participation-conditions a{font-weight:700}
.public-initials{display:inline-flex;align-items:center;justify-content:center;min-width:64px;padding:7px 10px;border-radius:999px;background:#f3efe8;border:1px solid var(--line);font-weight:750;letter-spacing:.04em;color:#2a2520}
.footer-org{align-items:center;gap:16px}.footer-logo-link{display:block;flex:0 0 auto;line-height:0}.footer-logo-link img{display:block;width:62px;height:62px;object-fit:contain}.footer-org-text{flex:1;min-width:180px}.footer-links{margin-left:auto}
@media(max-width:780px){.scoring-help-visual .scoring-help-head{display:grid;gap:12px}.scoring-help-visual .scoring-help-head strong{white-space:normal}.scoring-feature-grid{grid-template-columns:1fr 1fr}.footer-org{display:grid;grid-template-columns:70px 1fr;align-items:center}.footer-links{grid-column:1 / -1;margin-left:0}.footer-logo-link img{width:58px;height:58px}}
@media(max-width:520px){.scoring-feature-grid{grid-template-columns:1fr}.scoring-feature-card{min-height:auto}.public-initials{min-width:54px}.footer-org{grid-template-columns:1fr;text-align:center}.footer-logo-link img{margin:0 auto}}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.19
   Popup público para avisos importantes de participación duplicada. */
.public-popup-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.58);display:none;align-items:center;justify-content:center;padding:22px;z-index:9999;backdrop-filter:blur(4px)}
.public-popup-backdrop.is-open{display:flex}
.public-popup{position:relative;width:min(520px,100%);background:#fff;border-radius:28px;padding:30px 28px 26px;box-shadow:0 24px 70px rgba(0,0,0,.28);text-align:center;border:1px solid rgba(217,164,65,.35);animation:popupIn .18s ease-out}
.public-popup-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border:0;border-radius:999px;background:#f2eee7;color:#222;font-size:24px;line-height:1;cursor:pointer}
.public-popup-icon{width:58px;height:58px;border-radius:18px;margin:0 auto 14px;display:grid;place-items:center;background:#fff3cd;color:#6a4b05;font-family:Manrope,Inter,system-ui,sans-serif;font-size:34px;font-weight:750;border:1px solid #efd28a}
.public-popup h2{margin:0 0 10px;font-size:clamp(24px,5vw,34px);font-weight:750;letter-spacing:-.03em;color:#181818}
.public-popup p{margin:0 0 22px;color:#5d554d;font-size:16px;line-height:1.55}
.public-popup .btn{width:100%;max-width:260px;margin:0 auto}
@keyframes popupIn{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
@media(max-width:520px){.public-popup{padding:28px 20px 22px;border-radius:24px}.public-popup .btn{max-width:100%}}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.20
   Apuesta pública con campeón del Mundial, paginación admin y votos de prueba. */
.public-bet-line{display:block;line-height:1.35;color:#2a2520}
.public-bet-world{margin-top:3px;color:#7a5a17;font-weight:650}
.admin-test-votes{margin:16px 0 18px;border:1px solid var(--line);border-radius:18px;background:#fbf8f1;overflow:hidden}
.admin-test-votes summary{cursor:pointer;padding:14px 16px;font-weight:650;color:#171717;list-style:none}
.admin-test-votes summary::-webkit-details-marker{display:none}
.admin-test-votes summary:before{content:'+';display:inline-grid;place-items:center;width:24px;height:24px;margin-right:9px;border-radius:999px;background:#171717;color:#fff;font-weight:600}
.admin-test-votes[open] summary:before{content:'−'}
.admin-test-votes-form{padding:0 16px 16px;display:grid;grid-template-columns:180px 1fr auto;gap:12px;align-items:end}
.admin-test-votes-form .hint{grid-column:1 / -1;margin:0}
.pagination-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:14px 0;padding:12px 14px;border:1px solid var(--line);border-radius:16px;background:#fff}
.pagination-bar-bottom{margin-top:16px}.pagination-actions{display:flex;gap:8px;flex-wrap:wrap}.pagination-bar span{color:#6b625b;font-size:14px}
@media(max-width:780px){.admin-test-votes-form{grid-template-columns:1fr}.pagination-bar{display:grid}.pagination-actions .btn{flex:1}.public-bet-line{font-size:14px}}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.21
   Legal en popup, sponsor con web, localidad pública y resultados más votados. */
.inline-legal-link{display:inline;color:#7a5613;background:transparent;border:0;padding:0;margin:0;font:inherit;font-weight:700;text-decoration:underline;cursor:pointer}
.legal-acceptance-box{margin:20px 0 14px;padding:18px;border:1px solid #ead8a8;background:linear-gradient(135deg,#fff9e9,#fff);border-radius:18px}
.legal-acceptance-box h3{margin:0 0 6px}.legal-acceptance-box p{margin:0 0 12px;color:#5a5148}
.legal-popup{width:min(720px,100%);text-align:left;max-height:88vh;display:flex;flex-direction:column}
.legal-popup > h2{text-align:center;margin-bottom:12px}.legal-popup-icon{margin-left:auto;margin-right:auto}
.legal-popup-content{overflow:auto;padding:4px 6px 4px 0;margin:0 0 20px;line-height:1.48;color:#4e463e}
.legal-popup-content h3{font-size:17px;margin:16px 0 5px;color:#171717}.legal-popup-content p{margin:0 0 8px;font-size:15px}.legal-popup-content a{font-weight:700;color:#171717}
.sponsor-web-link{display:inline-flex;align-items:center;gap:6px;text-decoration:none;color:#171717}.sponsor-web-link:hover{text-decoration:underline}.sponsor-web-link:after{content:'↗';font-size:12px;color:#b68422}
.public-locality{display:block;margin-top:5px;color:#7a7168;font-size:13px;font-weight:500;letter-spacing:-.01em}.public-locality:before{content:'📍 ';font-size:12px}
.estado-top-results{margin-top:18px;border:1px solid var(--line);border-radius:18px;background:#fff;padding:16px}.estado-top-results h3{margin:0 0 12px}.top-result-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-top:1px solid #eee5d9}.top-result-row:first-of-type{border-top:0}.top-result-row strong{font-family:var(--font-display);font-size:18px}.top-result-row span{background:#f4f1ec;border:1px solid var(--line);border-radius:999px;padding:5px 10px;color:#5d554d;font-size:13px;white-space:nowrap}
.legal-card h2{margin-top:24px}.legal-card h2:first-child{margin-top:0}.legal-card p,.legal-card li{line-height:1.6}.legal-card ul{padding-left:22px}
@media(max-width:780px){.legal-popup{max-height:92vh}.top-result-row{align-items:flex-start;flex-direction:column}.top-result-row span{white-space:normal}.public-locality{font-size:12px}}
.sponsor-small-link{display:inline-flex;margin-top:6px;color:#7a5613;font-weight:650;font-size:13px;text-decoration:none}.sponsor-small-link:hover{text-decoration:underline}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.23
   Resultado en directo: marcador único calculado desde goles y borrado de goles anulados. */
.resultado-live-card .section-head{align-items:center}
.resultado-score-admin{display:flex;align-items:center;gap:10px;background:#171717;color:#fff;border-radius:18px;padding:14px 18px;min-width:220px;justify-content:center}
.resultado-score-admin span{font-size:13px;color:#d9d9d9}
.resultado-score-admin strong{font-family:Manrope,Inter,Arial,sans-serif;font-size:30px;font-weight:700 !important;line-height:1;color:#d9a441;white-space:nowrap}
.resultado-admin-note{background:#fff8df;border:1px solid #ead8a8;color:#46381c;border-radius:14px;padding:13px 15px;margin:12px 0 18px;line-height:1.45}
.resultado-derived-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:10px 0 16px}
.resultado-derived-grid div{background:#fbf8f1;border:1px solid var(--line);border-radius:14px;padding:14px}
.resultado-derived-grid span{display:block;color:var(--muted);font-size:13px;margin-bottom:4px}
.resultado-derived-grid strong{font-size:18px;font-weight:600 !important}
.goles-admin-table .inline-form{margin:0;display:inline-flex}.goles-admin-table td:last-child{width:110px}
@media(max-width:780px){.resultado-live-card .section-head{display:block}.resultado-score-admin{margin-top:12px;width:100%}.resultado-derived-grid{grid-template-columns:1fr}}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.24
   Edición de goles y filtros de validación en participaciones admin. */
.inline-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.inline-actions .inline-form{margin:0}
.goal-edit-modal{max-width:720px}
.filter-summary{display:inline-flex;align-items:center;gap:6px;margin:10px 0 16px;padding:8px 12px;border:1px solid var(--line);border-radius:12px;background:#fbf8f1;color:#5f5750;font-size:14px}
.admin-filter-form .grid{align-items:end}
.goles-admin-table td:last-child{min-width:160px}
@media(max-width:780px){.inline-actions{align-items:stretch}.inline-actions .btn,.inline-actions .inline-form{width:100%}.inline-actions .inline-form .btn{width:100%}.filter-summary{display:flex;width:100%}}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.26
   Gestión de jugadores activos y formulario de goles más claro. */
.field-note{display:block;color:var(--muted);font-size:12px;font-weight:400;margin-top:2px;text-transform:none;letter-spacing:0}
.other-spain-field{max-width:460px;margin-top:10px}
.goal-admin-form .hint{margin-top:12px}
.players-porra-note{border:1px solid var(--line);background:#fbf8f1;border-radius:16px;padding:14px 16px;margin:16px 0;color:#3a342f}
.players-porra-note strong{display:block;margin-bottom:4px}.players-porra-note p{margin:6px 0}.players-porra-note a{text-decoration:underline;text-underline-offset:3px}
.players-admin-table input[type="text"],.players-admin-table input:not([type]){min-width:220px}.players-admin-table input[type="number"]{max-width:90px}.table-check{margin:0}.player-active-check{align-items:center;margin-top:28px}.form-align-end{display:flex;align-items:end}.left-actions{justify-content:flex-start;margin-top:14px}
.goal-edit-modal .grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
@media(max-width:780px){.goal-edit-modal .grid.two{grid-template-columns:1fr}.form-align-end{align-items:stretch}.form-align-end .btn{width:100%}}


/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.28
   Filtros claros de validación en participaciones. */
.validation-filter-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0 10px;align-items:center}
.validation-filter-tabs .btn{min-height:36px;padding:8px 12px;border-radius:12px}
.btn-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:22px;padding:0 7px;border-radius:999px;background:rgba(255,255,255,.18);font-size:12px;margin-left:4px}
.btn-outline .btn-count{background:#eee6db;color:#222}
.empty-state-inline{padding:18px;border:1px dashed var(--line);border-radius:14px;background:#fbf8f1;color:var(--muted);text-align:center}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.29
   Menú superior público y recuperación de contraseña admin. */
.top-menu{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  background:rgba(255,255,255,.86);
  border:1px solid var(--line);
  border-radius:22px;
  padding:10px 12px;
  margin:0 0 16px;
  box-shadow:0 8px 20px rgba(0,0,0,.045);
  backdrop-filter:blur(8px);
}
.top-menu-brand{
  text-decoration:none;
  font-family:Manrope,Inter,"Segoe UI",Roboto,Arial,sans-serif;
  font-weight:750;
  letter-spacing:-.025em;
  color:#171717;
  padding:9px 12px;
  white-space:nowrap;
}
.top-menu-links{display:flex;align-items:center;justify-content:flex-end;gap:6px;flex-wrap:wrap}
.top-menu-links a{
  text-decoration:none;
  color:#171717;
  border:1px solid transparent;
  border-radius:999px;
  padding:8px 12px;
  font-size:14px;
  font-weight:600;
  line-height:1;
}
.top-menu-links a:hover{background:#f7f1e5;border-color:#ead28a}
.top-menu-links .top-menu-gold{background:#d9a441;color:#111;border-color:#d9a441}
.top-menu-links .top-menu-gold:hover{background:#c8952f;border-color:#c8952f}
.admin-quick-menu{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.login-shell{width:min(980px,100%);margin:0 auto;padding:18px}
.login-shell .top-menu{margin-bottom:18px}
.login-card{margin:0 auto}
.login-links{margin-top:18px;text-align:center;color:var(--muted);font-size:14px}
.login-links a{color:#171717;font-weight:650;text-decoration:none;border-bottom:1px solid rgba(0,0,0,.25)}
.login-links a:hover{border-bottom-color:#171717}
@media(max-width:780px){
  .top-menu{display:block;padding:10px;margin-bottom:12px}
  .top-menu-brand{display:block;text-align:center;padding:10px 8px 8px}
  .top-menu-links{justify-content:center;gap:6px}
  .top-menu-links a{font-size:13px;padding:8px 10px}
  .admin-quick-menu{justify-content:flex-start;width:100%}
  .admin-quick-menu .btn{flex:1 1 auto}
  .login-shell{padding:12px}
}


/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.30
   Admin con menú superior y refuerzo móvil-first. */
.admin-body-topnav{background:var(--bg)}
.admin-shell{min-height:100vh;width:100%}
.admin-body-topnav .admin-layout{display:block;min-height:100vh}
.admin-topbar{position:sticky;top:0;z-index:90;background:rgba(17,17,17,.96);color:#fff;border-bottom:1px solid rgba(255,255,255,.12);box-shadow:0 10px 28px rgba(0,0,0,.16);backdrop-filter:blur(10px)}
.admin-topbar-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px clamp(12px,3vw,24px) 8px}
.admin-topbar-brand{display:flex;align-items:center;gap:10px;color:#fff;text-decoration:none;min-width:0;font-family:Manrope,Inter,"Segoe UI",Roboto,Arial,sans-serif;font-size:18px;font-weight:500;letter-spacing:-.02em;line-height:1.05}
.admin-topbar-brand img{width:44px;height:44px;object-fit:contain;display:block;flex:0 0 auto}
.admin-topbar-brand strong{font-weight:750;color:#d9a441}
.admin-topbar-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.admin-topbar-actions a{color:#fff;text-decoration:none;border:1px solid rgba(255,255,255,.22);border-radius:999px;padding:8px 11px;font-size:13px;font-weight:550;white-space:nowrap;background:rgba(255,255,255,.06)}
.admin-topbar-actions a:hover{background:rgba(255,255,255,.14)}
.admin-topbar-actions .admin-topbar-logout{background:#d9a441;color:#111;border-color:#d9a441}
.admin-topnav{border-top:1px solid rgba(255,255,255,.1);padding:0 clamp(8px,2vw,20px) 9px}
.admin-topnav-scroll{display:flex;align-items:center;gap:7px;overflow-x:auto;overflow-y:hidden;padding:9px 2px 2px;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.32) transparent}
.admin-topnav-scroll::-webkit-scrollbar{height:7px}
.admin-topnav-scroll::-webkit-scrollbar-track{background:transparent}
.admin-topnav-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.28);border-radius:999px}
.admin-topnav-scroll a{flex:0 0 auto;color:#fff;text-decoration:none;border-radius:999px;padding:9px 13px;background:rgba(255,255,255,.075);font-size:14px;font-weight:520;white-space:nowrap;line-height:1}
.admin-topnav-scroll a:hover{background:rgba(255,255,255,.16)}
.admin-version-line{display:none;color:#c8c8c8;font-size:12px;padding:0 16px 10px;text-align:center}
.admin-body-topnav .sidebar{display:none!important}
.admin-body-topnav .admin-main,.admin-body-topnav .admin-main-topnav{margin-left:0!important;padding:clamp(12px,2.4vw,26px);max-width:1400px;margin-right:auto;margin-left:auto!important;width:100%}
.admin-body-topnav .admin-top{align-items:flex-start;gap:10px;margin-bottom:14px}
.admin-body-topnav .admin-top h1{font-size:clamp(25px,4.5vw,34px);line-height:1.05}
.admin-body-topnav .admin-quick-menu{justify-content:flex-end}

@media(max-width:780px){
  .site-wrap{padding:10px}
  .public-body .top-menu{position:sticky;top:0;z-index:70;border-radius:0;margin:-10px -10px 12px;padding:8px 8px 9px;border-left:0;border-right:0;border-top:0;box-shadow:0 6px 18px rgba(0,0,0,.08)}
  .public-body .top-menu-brand{text-align:left;font-size:15px;padding:6px 8px;white-space:normal}
  .public-body .top-menu-links{justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;gap:6px;padding:2px 0 4px;-webkit-overflow-scrolling:touch}
  .public-body .top-menu-links a{flex:0 0 auto;min-height:38px;display:inline-flex;align-items:center;font-size:13px;padding:9px 11px}
  .admin-topbar{position:sticky;top:0}
  .admin-topbar-head{display:block;padding:10px 10px 6px}
  .admin-topbar-brand{justify-content:center;font-size:17px;margin-bottom:8px;text-align:center}
  .admin-topbar-brand img{width:38px;height:38px}
  .admin-topbar-actions{justify-content:center;gap:6px}
  .admin-topbar-actions a{font-size:12.5px;padding:8px 10px;min-height:36px;display:inline-flex;align-items:center}
  .admin-topnav{padding:0 6px 8px}
  .admin-topnav-scroll{gap:6px;padding-top:7px}
  .admin-topnav-scroll a{font-size:13px;padding:9px 11px;min-height:38px;display:inline-flex;align-items:center}
  .admin-body-topnav .admin-main,.admin-body-topnav .admin-main-topnav{padding:10px}
  .admin-body-topnav .admin-top{display:block;margin-bottom:12px}
  .admin-body-topnav .admin-top h1{margin-bottom:10px}
  .admin-body-topnav .admin-quick-menu{display:grid;grid-template-columns:1fr;gap:8px}
  .admin-body-topnav .admin-quick-menu .btn{width:100%;min-height:40px}
  .card,.match-card{padding:16px;border-radius:18px;margin:12px 0}
  .table-wrap{margin-left:-4px;margin-right:-4px}
  input,select,textarea{font-size:16px;min-height:44px}
  .btn{min-height:42px}
}

@media(max-width:430px){
  .admin-topbar-actions{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
  .admin-topbar-actions a{text-align:center;justify-content:center}
  .admin-topbar-actions .admin-topbar-logout{grid-column:1 / -1}
  .hero{border-radius:20px;padding:18px}
  .hero p{font-size:16px}
  .question-block{padding:14px;border-radius:16px}
}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.31
   Menús agrupados para evitar desbordes en móvil y mejorar la navegación del admin. */
.top-menu-group,
.admin-menu-group{position:relative}
.top-menu-group summary,
.admin-menu-group summary{list-style:none;cursor:pointer;user-select:none}
.top-menu-group summary::-webkit-details-marker,
.admin-menu-group summary::-webkit-details-marker{display:none}
.top-menu-group summary{display:inline-flex;align-items:center;justify-content:center;gap:7px;border-radius:999px;border:1px solid #ead28a;background:#fff8e8;color:#171717;padding:9px 13px;font-size:14px;font-weight:750;line-height:1;white-space:nowrap}
.top-menu-group summary:after,.admin-menu-group summary:after{content:'▾';font-size:11px;opacity:.75;transform:translateY(-1px)}
.top-menu-group[open] summary:after,.admin-menu-group[open] summary:after{content:'▴'}
.public-menu-group .top-menu-links{display:grid;grid-template-columns:1fr;gap:6px;position:absolute;right:0;top:calc(100% + 8px);z-index:120;min-width:220px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:10px;box-shadow:0 22px 50px rgba(0,0,0,.16)}
.public-menu-group .top-menu-links a{display:flex;align-items:center;justify-content:flex-start;border-radius:12px;padding:10px 12px;min-height:40px}
.public-menu-group:not([open]) .top-menu-links{display:none}
.admin-topnav.admin-topnav-grouped{display:flex;align-items:center;gap:8px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.1);padding:8px clamp(12px,3vw,24px) 11px;overflow:visible}
.admin-menu-group summary{display:inline-flex;align-items:center;justify-content:center;gap:7px;color:#fff;text-decoration:none;border-radius:999px;padding:10px 14px;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.14);font-size:14px;font-weight:650;white-space:nowrap;line-height:1;min-height:40px}
.admin-menu-group[open] summary,.admin-menu-group summary:hover{background:#d9a441;color:#111;border-color:#d9a441}
.admin-menu-dropdown{position:absolute;top:calc(100% + 8px);left:0;z-index:130;display:grid;gap:6px;min-width:235px;background:#fff;color:#171717;border:1px solid var(--line);border-radius:18px;padding:10px;box-shadow:0 24px 55px rgba(0,0,0,.2)}
.admin-menu-dropdown a{display:flex;align-items:center;min-height:40px;padding:10px 12px;border-radius:12px;color:#171717;text-decoration:none;font-weight:600;font-size:14px;line-height:1.15;background:#fff}
.admin-menu-dropdown a:hover{background:#f7f1e5;color:#111}
.admin-body-topnav .admin-top{margin-top:4px}
.admin-quick-menu{display:none!important}
@media(max-width:780px){
  .top-menu{display:flex;align-items:center;justify-content:space-between;padding:9px 10px}
  .top-menu-brand{display:block;text-align:left;padding:8px 6px;font-size:15px;max-width:68%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .public-menu-group .top-menu-links{right:0;left:auto;min-width:min(245px,calc(100vw - 24px));max-width:calc(100vw - 24px)}
  .public-body .top-menu-links{overflow:visible;flex-wrap:initial;padding:10px}
  .admin-topbar-head{display:grid;grid-template-columns:1fr;gap:8px;padding:9px 10px 7px}
  .admin-topbar-brand{justify-content:center;margin-bottom:0}
  .admin-topbar-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;width:100%}
  .admin-topbar-actions a{font-size:12px;padding:8px 7px;min-height:36px;justify-content:center;text-align:center}
  .admin-topbar-actions .admin-topbar-logout{grid-column:auto}
  .admin-topnav.admin-topnav-grouped{display:grid;grid-template-columns:1fr 1fr;gap:7px;padding:0 8px 9px;border-top:0}
  .admin-menu-group{min-width:0}
  .admin-menu-group summary{width:100%;min-height:39px;padding:9px 8px;font-size:13px}
  .admin-menu-dropdown{position:static;min-width:0;margin-top:6px;border-radius:14px;padding:7px;box-shadow:none;background:rgba(255,255,255,.96)}
  .admin-menu-dropdown a{font-size:13px;min-height:38px;padding:9px 10px}
  .admin-body-topnav .admin-top h1{font-size:24px;margin-bottom:4px}
}
@media(max-width:430px){
  .admin-topbar-actions{grid-template-columns:1fr 1fr}
  .admin-topbar-actions .admin-topbar-logout{grid-column:1 / -1}
  .admin-topnav.admin-topnav-grouped{grid-template-columns:1fr 1fr}
  .admin-menu-group summary{font-size:12.5px}
}

/* v1.0.33 · Resultado en directo: aviso de gol rival genérico */
.goal-generic-note{
    border:1px dashed rgba(181,135,42,.55);
    border-radius:14px;
    padding:12px 14px;
    background:#fffaf0;
    color:#5f4b20;
    font-size:.94rem;
    line-height:1.35;
}
.goal-generic-note[hidden], .js-spain-player-field[hidden]{
    display:none !important;
}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.35
   Estadísticas admin y pantalla horizontal TV. */
.admin-stats-hero .section-head{align-items:flex-start}
.admin-stats-metrics{grid-template-columns:repeat(4,minmax(0,1fr))}
.admin-stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;align-items:start}
.admin-stats-subcard{margin-top:0}
.admin-stats-subcard h2{font-size:20px;margin-bottom:12px}
@media(max-width:1100px){.admin-stats-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-stats-grid{grid-template-columns:1fr}}
@media(max-width:640px){.admin-stats-metrics{grid-template-columns:1fr}}

.tv-body{margin:0;background:#070707;color:#fff;font-family:Inter,"Segoe UI",Roboto,Arial,sans-serif;overflow:hidden}
.tv-screen{min-height:100vh;width:100vw;padding:clamp(16px,2vw,28px);box-sizing:border-box;display:flex;flex-direction:column;gap:clamp(12px,1.6vw,22px);background:radial-gradient(circle at top left,rgba(217,164,65,.28),transparent 35%),linear-gradient(135deg,#0b0b0b,#17110a 52%,#070707)}
.tv-screen-empty{align-items:center;justify-content:center;text-align:center}.tv-screen-empty img{width:min(280px,45vw);height:auto;margin-bottom:18px}.tv-screen-empty h1{font-size:clamp(42px,6vw,86px);margin:0}.tv-screen-empty p{font-size:clamp(18px,2vw,28px);color:#d8cbb8;max-width:900px}
.tv-header{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:78px}.tv-brand{display:flex;align-items:center;gap:18px;min-width:0}.tv-brand img{width:86px;height:86px;object-fit:contain}.tv-brand span{display:block;text-transform:uppercase;letter-spacing:.16em;color:#d9a441;font-size:14px;font-weight:800}.tv-brand strong{display:block;font-family:Manrope,Inter,sans-serif;font-size:clamp(28px,3vw,54px);line-height:1.03;letter-spacing:-.045em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:58vw}.tv-status{display:grid;gap:4px;text-align:right}.tv-status span{display:inline-flex;justify-content:center;border:1px solid rgba(217,164,65,.55);background:rgba(217,164,65,.16);color:#ffe2a1;border-radius:999px;padding:10px 18px;font-size:clamp(18px,1.5vw,28px);font-weight:850;text-transform:uppercase;letter-spacing:.05em}.tv-status small{color:#c7b89f;font-size:14px}
.tv-main-grid{display:grid;grid-template-columns:minmax(420px,.92fr) 1.08fr;gap:clamp(14px,1.6vw,24px)}
.tv-score-card{border:1px solid rgba(255,255,255,.12);border-radius:30px;background:rgba(255,255,255,.075);box-shadow:0 24px 80px rgba(0,0,0,.24);padding:clamp(20px,2.2vw,34px);display:grid;grid-template-columns:1fr auto 1fr;gap:16px;align-items:center}.tv-score-line{display:grid;gap:10px;text-align:center}.tv-score-line span{font-size:clamp(22px,2.3vw,42px);font-weight:850;letter-spacing:-.035em}.tv-score-line strong{font-family:Manrope,Inter,sans-serif;font-size:clamp(94px,11vw,190px);line-height:.85;color:#fff;text-shadow:0 8px 38px rgba(217,164,65,.18)}.tv-score-separator{font-family:Manrope,Inter,sans-serif;font-size:clamp(56px,5vw,96px);font-weight:800;color:#d9a441}.tv-score-extra{grid-column:1 / -1;display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px}.tv-score-extra div{background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:12px 16px}.tv-score-extra span{display:block;color:#c7b89f;font-size:14px;text-transform:uppercase;letter-spacing:.06em}.tv-score-extra strong{font-family:Manrope,Inter,sans-serif;font-size:clamp(20px,1.8vw,34px);line-height:1.05;color:#ffe2a1}
.tv-metrics-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.tv-metrics-grid div,.tv-panel{border:1px solid rgba(255,255,255,.12);border-radius:24px;background:rgba(255,255,255,.078);box-shadow:0 24px 80px rgba(0,0,0,.22)}.tv-metrics-grid div{padding:clamp(16px,1.7vw,26px);display:grid;align-content:center;min-height:120px}.tv-metrics-grid strong{font-family:Manrope,Inter,sans-serif;font-size:clamp(24px,2.2vw,42px);line-height:1.03;color:#fff;letter-spacing:-.035em}.tv-metrics-grid span{margin-top:8px;color:#c7b89f;text-transform:uppercase;letter-spacing:.08em;font-size:13px;font-weight:800}
.tv-content-grid{display:grid;grid-template-columns:1.3fr .9fr .9fr .9fr;gap:clamp(12px,1.4vw,20px);min-height:0;flex:1}.tv-panel{padding:clamp(14px,1.5vw,22px);min-height:0;overflow:hidden}.tv-panel-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.tv-panel-head h2{margin:0;font-family:Manrope,Inter,sans-serif;font-size:clamp(20px,1.6vw,32px);letter-spacing:-.035em}.tv-panel-head span{border:1px solid rgba(217,164,65,.45);border-radius:999px;padding:6px 10px;color:#ffe2a1;font-weight:800}.tv-ranking-list{display:grid;gap:7px}.tv-ranking-row{display:grid;grid-template-columns:58px minmax(0,1fr) 78px minmax(120px,.95fr);gap:10px;align-items:center;border-top:1px solid rgba(255,255,255,.09);padding:8px 0}.tv-ranking-row:first-child{border-top:0}.tv-position{display:inline-grid;place-items:center;width:46px;height:34px;border-radius:999px;background:#d9a441;color:#111;font-weight:900}.tv-ranking-row strong{display:block;font-size:clamp(17px,1.2vw,23px)}.tv-ranking-row small{display:block;color:#c7b89f;margin-top:3px}.tv-ranking-row b{color:#ffe2a1;font-size:clamp(17px,1.2vw,24px);white-space:nowrap}.tv-ranking-row em{font-style:normal;color:#d8cbb8;font-size:clamp(13px,.9vw,16px);line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tv-empty{color:#c7b89f;padding:18px;border:1px dashed rgba(255,255,255,.16);border-radius:16px;text-align:center}.tv-bars{display:grid;gap:12px}.tv-bar-row{display:grid;grid-template-columns:minmax(0,1fr) 35% 42px;gap:10px;align-items:center}.tv-bar-label{font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tv-bar-track{height:13px;border-radius:999px;background:rgba(255,255,255,.12);overflow:hidden}.tv-bar-track span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#d9a441,#ffe2a1)}.tv-bar-row strong{color:#ffe2a1;text-align:right}.tv-sponsors{display:flex;align-items:center;gap:12px;min-height:78px;border-top:1px solid rgba(255,255,255,.12);padding-top:12px;overflow:hidden}.tv-sponsors>span{text-transform:uppercase;letter-spacing:.12em;font-size:12px;font-weight:900;color:#d9a441;white-space:nowrap}.tv-sponsor-item{display:flex;align-items:center;gap:9px;border:1px solid rgba(255,255,255,.12);border-radius:18px;background:rgba(255,255,255,.07);padding:8px 12px;min-width:0}.tv-sponsor-item img{width:42px;height:42px;object-fit:contain;border-radius:10px;background:#fff}.tv-sponsor-item strong{white-space:nowrap}.tv-sponsor-item small{color:#d8cbb8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}
@media(max-width:1100px){.tv-body{overflow:auto}.tv-screen{min-height:100vh}.tv-main-grid,.tv-content-grid{grid-template-columns:1fr}.tv-brand strong{white-space:normal;max-width:none}.tv-ranking-row{grid-template-columns:54px minmax(0,1fr) 78px}.tv-ranking-row em{grid-column:2 / -1}.tv-sponsors{flex-wrap:wrap;height:auto}.tv-metrics-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.tv-header{display:grid}.tv-status{text-align:left}.tv-score-card{grid-template-columns:1fr auto 1fr;border-radius:22px}.tv-score-extra{grid-template-columns:1fr}.tv-metrics-grid{grid-template-columns:1fr}.tv-brand img{width:64px;height:64px}.tv-brand strong{font-size:28px}.tv-score-line strong{font-size:78px}.tv-score-line span{font-size:20px}}


/* v1.0.42 · Participaciones: buscador dinámico y acciones masivas */
.bulk-actions-form {
    margin: 16px 0;
    padding: 14px;
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(255,255,255,.92), rgba(246,240,229,.82));
}
.bulk-actions-inner {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.bulk-action-select {
    min-width: 210px;
}
.bulk-check-col {
    width: 38px;
    text-align: center;
}
.bulk-check-col input[type="checkbox"] {
    width: 18px;
    height: 18px;
    cursor: pointer;
}
#bulk-submit-btn:disabled {
    opacity: .45;
    cursor: not-allowed;
}
@media (max-width: 760px) {
    .bulk-actions-inner {
        align-items: stretch;
        flex-direction: column;
    }
    .bulk-action-select,
    .bulk-actions-inner .btn {
        width: 100%;
    }
}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.51
   Home móvil: botón hazte socio, cinco pasos de voto y recomendación de socio. */
.btn-gold{
  background:linear-gradient(135deg,#d9a441,#f2cc73);
  color:#15110a;
  border:1px solid rgba(122,86,19,.22);
  box-shadow:0 10px 24px rgba(217,164,65,.22);
}
.btn-gold:hover{filter:brightness(.98);text-decoration:none}
.home-member-cta{
  display:grid;
  grid-template-columns:54px 1fr auto;
  align-items:center;
  gap:14px;
  margin:14px 0 6px;
  padding:13px 14px;
  border:1px solid rgba(217,164,65,.36);
  border-radius:20px;
  background:linear-gradient(135deg,#fff8e7,#fff);
  box-shadow:0 14px 36px rgba(40,30,10,.08);
}
.home-member-cta img{
  width:54px;
  height:54px;
  object-fit:contain;
  border-radius:14px;
  background:#fff;
  box-shadow:0 8px 20px rgba(0,0,0,.08);
}
.home-member-copy{display:grid;gap:3px;min-width:0}
.home-member-copy strong{
  color:#16120a;
  font-family:Manrope,Inter,system-ui,sans-serif;
  font-size:16px;
  font-weight:900;
  line-height:1.1;
}
.home-member-cta span{
  color:#5f5345;
  font-size:14px;
  font-weight:700;
  line-height:1.35;
}
.home-member-cta-empty{max-width:760px;margin:18px auto}
.btn-home-member{padding:12px 18px;white-space:nowrap}
.vote-steps-card{
  background:linear-gradient(135deg,#161616,#29231a);
  color:#fff;
  overflow:hidden;
  position:relative;
}
.vote-steps-card:before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 12% 0%,rgba(217,164,65,.28),transparent 34%),radial-gradient(circle at 95% 15%,rgba(255,255,255,.08),transparent 30%);
  pointer-events:none;
}
.vote-steps-card>*{position:relative;z-index:1}
.steps-head{display:grid;gap:6px;margin-bottom:18px}
.steps-head h2{margin:0;font-size:clamp(28px,5vw,46px);line-height:.98;letter-spacing:-.045em;color:#fff}
.steps-head p{margin:0;color:#e8ddc8;font-size:16px;line-height:1.45;max-width:720px}
.vote-steps-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.vote-step{
  min-height:155px;
  padding:18px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.vote-step strong{
  display:grid;
  place-items:center;
  width:44px;
  height:44px;
  border-radius:50%;
  background:linear-gradient(135deg,#d9a441,#f3d179);
  color:#111;
  font-family:Manrope,Inter,system-ui,sans-serif;
  font-size:24px;
  line-height:1;
  font-weight:900;
  margin-bottom:12px;
}
.vote-step h3{margin:0 0 7px;color:#fff;font-size:19px;line-height:1.1}
.vote-step p{margin:0;color:#ddd2c1;font-size:14px;line-height:1.38}
.vote-step-highlight{border-color:rgba(217,164,65,.55);background:linear-gradient(135deg,rgba(217,164,65,.20),rgba(255,255,255,.08))}
.steps-member-recommendation{display:grid;grid-template-columns:58px 1fr auto;align-items:center;gap:14px;margin:18px 0 0;padding:14px 16px;border-radius:22px;background:rgba(255,255,255,.10);border:1px solid rgba(217,164,65,.38)}
.steps-member-recommendation img{width:58px;height:58px;object-fit:contain;border-radius:15px;background:#fff}
.steps-member-recommendation strong{display:block;color:#f3d179;font-family:Manrope,Inter,system-ui,sans-serif;font-size:15px;font-weight:950;text-transform:uppercase;letter-spacing:.06em}
.steps-member-recommendation span{display:block;margin-top:3px;color:#f2e8d7;font-size:15px;line-height:1.35;font-weight:650}
.steps-member-recommendation b{color:#fff}
.form-intro{
  margin:4px 0 18px;
  padding:14px 16px;
  border-radius:16px;
  background:#fbf8f1;
  border:1px solid var(--line);
  color:#594f45;
  font-weight:650;
  line-height:1.45;
}
.form-card .scoring-help-visual{
  margin:20px 0 18px;
}
@media(max-width:1100px){
  .vote-steps-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:900px){
  .vote-steps-grid{grid-template-columns:repeat(2,1fr)}
  .steps-member-recommendation{grid-template-columns:1fr;text-align:center}
  .steps-member-recommendation img{margin:0 auto}
  .steps-member-recommendation .btn{width:100%}
}
@media(max-width:620px){
  .home-member-cta{grid-template-columns:1fr;gap:10px;text-align:center}
  .home-member-cta img{margin:0 auto}
  .btn-home-member{width:100%}
  .vote-steps-grid{grid-template-columns:1fr}
  .vote-step{display:grid;grid-template-columns:54px 1fr;gap:0 12px;min-height:auto;padding:16px}
  .vote-step strong{grid-row:1 / span 2;margin:0;width:46px;height:46px}
  .vote-step h3{margin-top:2px}
  .vote-step p{font-size:14px}
  .steps-head h2{font-size:34px}
  .steps-head p{font-size:15px}
}


/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.52
   Numeración visible junto a los campos del formulario de voto. */
.form-step-heading{display:flex;align-items:flex-start;gap:14px;margin:18px 0 14px}
.form-step-heading h3{margin:0 0 4px;font-size:22px;line-height:1.05;font-weight:800!important;letter-spacing:-.02em!important;color:#171717}
.form-step-heading p{margin:0;color:var(--muted);font-size:14px;line-height:1.35}
.form-step-heading-compact{margin:0 0 14px}
.form-step-number{flex:0 0 auto;display:inline-grid;place-items:center;width:42px;height:42px;border-radius:999px;background:#111;color:#fff;font-size:20px;font-weight:900!important;line-height:1;box-shadow:0 8px 18px rgba(0,0,0,.12)}
.form-step-number-soft{background:#d9a441;color:#111}
.form-numbered-grid{margin-bottom:18px}
.field-label-main{display:block;font-weight:800!important;color:#171717;margin-bottom:4px}
.question-block-numbered{position:relative;padding-top:20px}
.legal-acceptance-numbered .form-step-heading{margin-bottom:12px}
@media(max-width:680px){.form-step-heading{gap:10px}.form-step-number{width:36px;height:36px;font-size:17px}.form-step-heading h3{font-size:19px}.form-step-heading p{font-size:13px}.question-block-numbered{padding:16px 14px}.score-inputs{gap:8px}.score-inputs span{font-size:28px}}

/* v1.0.53 · Premio visible en patrocinadores y puntos debajo del voto */
.sponsor-prize-public{display:flex;align-items:center;gap:8px;margin:.45rem 0 .35rem;font-weight:800;color:#171717}
.sponsor-prize-public span{display:inline-flex;align-items:center;border-radius:999px;background:#111;color:#fff;font-size:11px;line-height:1;padding:5px 8px;text-transform:uppercase;letter-spacing:.08em}
.form-card .legal-acceptance-numbered{margin-top:24px}
.form-card .btn-large + .scoring-help-visual{margin-top:28px}
@media(max-width:640px){.sponsor-prize-public{align-items:flex-start;flex-direction:column;gap:6px}.sponsor-prize-public span{font-size:10px}}


/* v1.0.54 · Texto de apuesta y aviso claro de un teléfono/email por porra */
.steps-rule-note{
  margin:16px 0 0;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(217,164,65,.14);
  border:1px solid rgba(217,164,65,.38);
  color:#f5ecd8;
  font-size:15px;
  line-height:1.42;
  font-weight:650;
}
.steps-rule-note strong{color:#f3d179;font-weight:950}
.steps-rule-note b{color:#fff;font-weight:900}
@media(max-width:640px){.steps-rule-note{font-size:14px;text-align:left}}

/* v1.0.60 · Fotos cuadradas de patrocinadores */
.sponsor-box-with-photo{display:grid;grid-template-columns:minmax(92px,140px) auto 1fr;align-items:center}
.sponsor-feature-photo{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:18px;background:#111;padding:0;max-width:none;max-height:none}
.sponsor-logo-wrap{display:flex;align-items:center;justify-content:center}
.sponsor-logo-wrap img{max-width:96px;max-height:72px;object-fit:contain;background:#fff;border-radius:12px;padding:8px}
.sponsor-photo-help{display:flex;align-items:center;min-height:46px}
@media(max-width:720px){.sponsor-box-with-photo{grid-template-columns:92px 1fr;gap:12px}.sponsor-box-with-photo .sponsor-logo-wrap{display:none}.sponsor-feature-photo{border-radius:14px}}

/* v1.0.61 · Patrocinadores independientes y asignación a porras */
.admin-thumb{width:58px;height:58px;object-fit:contain;background:#fff;border:1px solid var(--line);border-radius:12px;padding:6px}
.sponsor-select-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:12px 0 10px}
.sponsor-select-card{display:grid;grid-template-columns:52px 1fr;gap:12px;align-items:center;padding:12px;border:1px solid var(--line);border-radius:16px;background:#fbf8f1;cursor:pointer;min-height:78px}
.sponsor-select-card input{width:18px;height:18px;grid-row:1;align-self:start;margin:0;position:absolute;opacity:.001}
.sponsor-select-card img{width:52px;height:52px;object-fit:contain;background:#fff;border-radius:12px;padding:6px;border:1px solid #eadfd0}
.sponsor-select-card span{display:block;min-width:0}
.sponsor-select-card strong{display:block;color:#171717;font-size:15px;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sponsor-select-card small,.sponsor-select-card em{display:block;margin-top:5px;color:#6b6258;font-size:12px;line-height:1.25;font-style:normal;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sponsor-select-card:has(input:checked){background:#111;color:#fff;border-color:#d9a441;box-shadow:0 0 0 2px rgba(217,164,65,.18)}
.sponsor-select-card:has(input:checked) strong{color:#fff}.sponsor-select-card:has(input:checked) small{color:#f3d179}.sponsor-select-card.is-muted{opacity:.55}
@media(max-width:900px){.sponsor-select-grid{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.sponsor-select-grid{grid-template-columns:1fr}}


/* v1.0.66 home redesign */
.match-card-home{grid-template-columns:1fr}
.home-live-strip{display:grid;grid-template-columns:180px 1fr auto;gap:12px;align-items:center;background:#111;color:#fff;border-radius:18px;padding:14px 16px;margin:18px 0 12px}
.home-live-item span{display:block;color:#cfc4b1;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.home-live-item strong{display:block;margin-top:4px;font-size:22px;line-height:1.1}
.home-live-score strong{font-size:30px;font-weight:900}
.home-live-btn{white-space:nowrap;background:#fff;color:#111;border-color:#fff}
.sponsors-pills-wrap{margin-top:18px}
.sponsors-pills{display:grid;gap:14px;margin-top:10px}
.sponsor-pill{display:grid;grid-template-columns:74px 58px 1fr auto;gap:14px;align-items:center;background:#fbf8f1;border:1px solid var(--line);border-radius:20px;padding:14px 16px}
.sponsor-pill-photo{width:74px;height:74px;object-fit:cover;border-radius:16px;background:#fff;border:1px solid #eee7dc}
.sponsor-pill-logo{width:58px;height:58px;object-fit:contain;border-radius:14px;background:#fff;border:1px solid #eee7dc;padding:6px}
.sponsor-pill-copy strong{display:block;font-size:24px;line-height:1.05}
.sponsor-pill-copy span{display:block;margin-top:5px;font-size:18px;color:#171717}
.sponsor-pill-copy small{display:block;margin-top:6px;font-size:14px;color:var(--muted)}
.sponsor-pill-btn{white-space:nowrap}
.world-prize-home{margin-top:18px;display:grid;grid-template-columns:118px 1fr auto;gap:16px;align-items:center;background:linear-gradient(135deg,#19140a,#3c2c0f);color:#fff;border:1px solid rgba(217,164,65,.35);border-radius:24px;padding:18px;position:relative;overflow:hidden}
.world-prize-badge{position:absolute;top:14px;left:14px;background:#d9a441;color:#111;font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;border-radius:999px;padding:7px 10px}
.world-prize-photo{width:118px;height:118px;object-fit:cover;border-radius:18px;background:#fff;margin-top:22px}
.world-prize-copy strong{display:block;font-size:28px;line-height:1.05;margin-top:10px}
.world-prize-copy p{margin:8px 0 6px;font-size:17px;line-height:1.35;color:#f2e6c9}
.world-prize-copy span{display:block;font-size:14px;line-height:1.35;color:#dbcaa5}
.world-prize-btn{background:#fff;color:#111;border-radius:999px;white-space:nowrap}
@media(max-width:900px){.home-live-strip{grid-template-columns:1fr;align-items:flex-start}.home-live-score strong{font-size:24px}.sponsor-pill{grid-template-columns:74px 58px 1fr}.sponsor-pill-btn{grid-column:1/-1}.world-prize-home{grid-template-columns:96px 1fr}.world-prize-photo{width:96px;height:96px}.world-prize-btn{grid-column:1/-1}.world-prize-copy strong{font-size:24px}}
@media(max-width:720px){.sponsor-pill{grid-template-columns:60px 1fr;gap:12px}.sponsor-pill-logo{display:none}.sponsor-pill-photo{width:60px;height:60px}.sponsor-pill-copy strong{font-size:20px}.sponsor-pill-copy span{font-size:16px}.world-prize-home{grid-template-columns:1fr;text-align:left}.world-prize-photo{margin-top:26px}.world-prize-copy strong{margin-top:0}}


/* v1.0.67 */
.pending-email-big{margin:18px auto 16px;padding:18px 20px;border-radius:22px;background:linear-gradient(135deg,#111,#2d2616);color:#fff;font-size:clamp(26px,5vw,46px);line-height:1.05;font-weight:950;letter-spacing:-.04em;max-width:760px;box-shadow:0 18px 50px rgba(0,0,0,.18);border:1px solid rgba(217,164,65,.45)}
.pending-email-big:before{content:'✉️';display:block;font-size:34px;line-height:1;margin-bottom:8px}

/* v1.0.68 · Home: patrocinadores a la izquierda y premio gordo a la derecha */
.home-prizes-layout{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(280px,.85fr);gap:18px;align-items:stretch;margin-top:20px}
.home-prizes-layout-single{grid-template-columns:1fr}
.home-prizes-left,.home-prizes-right{min-width:0}
.home-prizes-left{background:#fbf8f1;border:1px solid var(--line);border-radius:24px;padding:18px;box-shadow:0 8px 20px rgba(0,0,0,.035)}
.home-prizes-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:12px}
.home-prizes-head h3{margin:0;font-size:26px;line-height:1.05;font-weight:800;letter-spacing:-.025em}
.home-prizes-layout .sponsors-pills{margin-top:0}
.home-prizes-layout .sponsor-pill{background:#fff;border-color:#eadfce;box-shadow:0 8px 18px rgba(0,0,0,.035)}
.home-prizes-layout .world-prize-home{height:100%;margin-top:0;grid-template-columns:1fr;align-content:start;padding:20px;background:radial-gradient(circle at top right,rgba(243,209,121,.34),transparent 34%),linear-gradient(135deg,#111,#332410 78%)}
.home-prizes-layout .world-prize-badge{position:static;display:inline-flex;width:max-content;margin-bottom:12px}
.home-prizes-layout .world-prize-photo{width:100%;height:auto;aspect-ratio:1/1;object-fit:cover;margin-top:0;border-radius:20px;max-height:260px}
.home-prizes-layout .world-prize-copy strong{margin-top:12px;font-size:clamp(24px,3.4vw,34px)}
.home-prizes-layout .world-prize-copy p{font-size:16px}
.home-prizes-layout .world-prize-btn{justify-self:start;margin-top:10px}
@media(max-width:900px){.home-prizes-layout{grid-template-columns:1fr}.home-prizes-layout .world-prize-photo{max-height:none}.home-prizes-head{display:block}.home-prizes-head h3{margin-top:6px}}


/* v1.0.69 · Ajuste fuerte de logos e imágenes en móvil */
.sponsor-pill,.world-prize-home,.home-member-cta{overflow:hidden}
.sponsor-pill img,.world-prize-home img,.home-member-cta img{display:block;max-width:100%}
.sponsor-pill-photo{width:74px!important;height:74px!important;min-width:74px;min-height:74px;aspect-ratio:1/1;object-fit:cover;flex:0 0 auto}
.sponsor-pill-logo{width:58px!important;height:58px!important;min-width:58px;min-height:58px;aspect-ratio:1/1;object-fit:contain;flex:0 0 auto}
.home-member-cta img{width:74px!important;height:74px!important;min-width:74px;min-height:74px;object-fit:contain}
.world-prize-photo{width:100%;max-width:260px;justify-self:center}
@media(max-width:720px){
  .home-prizes-left{padding:14px}
  .sponsor-pill{grid-template-columns:56px 1fr!important;gap:10px;padding:12px 12px 14px}
  .sponsor-pill-photo{width:56px!important;height:56px!important;min-width:56px;min-height:56px;border-radius:12px}
  .sponsor-pill-logo{display:none!important}
  .sponsor-pill-copy{min-width:0}
  .sponsor-pill-copy strong{font-size:18px;line-height:1.08}
  .sponsor-pill-copy span{font-size:15px;line-height:1.22}
  .sponsor-pill-copy small{font-size:13px;line-height:1.28}
  .sponsor-pill-btn{grid-column:1/-1;width:100%;text-align:center;justify-content:center}
  .world-prize-home{padding:16px}
  .world-prize-photo{max-width:220px;width:100%;margin:8px auto 0}
  .world-prize-copy strong{font-size:22px!important}
  .world-prize-copy p{font-size:15px!important}
}
@media(max-width:480px){
  .home-prizes-layout{gap:14px;margin-top:16px}
  .home-prizes-head h3{font-size:22px}
  .sponsor-pill{grid-template-columns:48px 1fr!important;gap:9px;padding:10px}
  .sponsor-pill-photo{width:48px!important;height:48px!important;min-width:48px;min-height:48px;border-radius:10px}
  .sponsor-pill-copy strong{font-size:17px}
  .sponsor-pill-copy span{font-size:14px}
  .sponsor-pill-copy small{font-size:12px}
  .home-member-cta{grid-template-columns:60px 1fr;gap:10px}
  .home-member-cta img{width:60px!important;height:60px!important;min-width:60px;min-height:60px}
  .btn-home-member{grid-column:1/-1}
  .world-prize-photo{max-width:180px}
}


/* v1.0.75 · Responsive móvil definitivo: bloqueo de imágenes/logos gigantes */
html,body{max-width:100%;overflow-x:hidden}
@media(max-width:820px){
  .public-body .site-wrap{max-width:100%;overflow:hidden}
  .hero-with-logo{
    display:grid!important;
    grid-template-columns:76px minmax(0,1fr)!important;
    align-items:center!important;
    gap:14px!important;
    padding:18px!important;
    overflow:hidden!important;
  }
  .hero-with-logo .public-logo-link{
    width:76px!important;
    height:76px!important;
    max-width:76px!important;
    max-height:76px!important;
    display:grid!important;
    place-items:center!important;
    overflow:hidden!important;
    flex:0 0 76px!important;
  }
  .hero-with-logo .public-logo-link img,
  .public-logo-link img{
    width:76px!important;
    height:76px!important;
    max-width:76px!important;
    max-height:76px!important;
    object-fit:contain!important;
    display:block!important;
  }
  .hero-copy{min-width:0!important}
  .hero-copy h1{font-size:clamp(28px,8vw,40px)!important;line-height:1.02!important;margin:.1rem 0 .35rem!important}
  .hero-copy p{font-size:15px!important;line-height:1.35!important}

  .home-member-cta{
    display:grid!important;
    grid-template-columns:58px minmax(0,1fr)!important;
    align-items:center!important;
    gap:10px!important;
    overflow:hidden!important;
  }
  .home-member-cta>img,
  .home-member-cta img{
    width:58px!important;
    height:58px!important;
    min-width:58px!important;
    min-height:58px!important;
    max-width:58px!important;
    max-height:58px!important;
    object-fit:contain!important;
    padding:2px!important;
    margin:0!important;
  }
  .home-member-copy{min-width:0!important}
  .home-member-copy strong,.home-member-copy span{overflow-wrap:anywhere}
  .btn-home-member{grid-column:1/-1!important;width:100%!important}

  .sponsors-grid{display:grid!important;grid-template-columns:1fr!important;gap:12px!important;overflow:hidden!important}
  .sponsor-box,
  .sponsor-box-with-photo,
  .sponsor-pill{
    display:grid!important;
    grid-template-columns:58px minmax(0,1fr)!important;
    gap:10px!important;
    align-items:center!important;
    overflow:hidden!important;
    min-width:0!important;
    padding:12px!important;
  }
  .sponsor-box img,
  .sponsor-box>img,
  .sponsor-feature-photo,
  .sponsor-pill-photo{
    width:58px!important;
    height:58px!important;
    min-width:58px!important;
    min-height:58px!important;
    max-width:58px!important;
    max-height:58px!important;
    aspect-ratio:1/1!important;
    object-fit:cover!important;
    border-radius:12px!important;
    padding:0!important;
    margin:0!important;
    grid-column:1!important;
    grid-row:1!important;
    display:block!important;
  }
  .sponsor-logo-wrap,
  .sponsor-pill-logo{
    display:none!important;
  }
  .sponsor-box>div,
  .sponsor-box .sponsor-web-link,
  .sponsor-pill-copy{
    min-width:0!important;
    grid-column:2!important;
  }
  .sponsor-box strong,
  .sponsor-pill-copy strong{
    font-size:18px!important;
    line-height:1.1!important;
    overflow-wrap:anywhere!important;
  }
  .sponsor-prize-public,
  .sponsor-pill-copy span{
    font-size:14px!important;
    line-height:1.25!important;
    overflow-wrap:anywhere!important;
  }
  .sponsor-box .hint,
  .sponsor-pill-copy small{
    font-size:12px!important;
    line-height:1.3!important;
    overflow-wrap:anywhere!important;
  }
  .sponsor-small-link,
  .sponsor-pill-btn{
    grid-column:1/-1!important;
    width:100%!important;
    justify-content:center!important;
    text-align:center!important;
    margin-top:4px!important;
  }

  .home-prizes-layout{display:grid!important;grid-template-columns:1fr!important;gap:14px!important;overflow:hidden!important}
  .home-prizes-left,.home-prizes-right,.world-prize-home{min-width:0!important;overflow:hidden!important}
  .world-prize-home{padding:16px!important;display:grid!important;grid-template-columns:1fr!important}
  .world-prize-photo,
  .home-prizes-layout .world-prize-photo{
    width:100%!important;
    max-width:210px!important;
    height:auto!important;
    max-height:210px!important;
    aspect-ratio:1/1!important;
    object-fit:cover!important;
    justify-self:center!important;
    margin:8px auto 0!important;
    display:block!important;
  }
  .world-prize-copy strong{font-size:22px!important;line-height:1.08!important;overflow-wrap:anywhere!important}
  .world-prize-copy p,.world-prize-copy span{font-size:14px!important;line-height:1.32!important;overflow-wrap:anywhere!important}

  .footer-logo-link img,
  .footer-org img{
    width:54px!important;
    height:54px!important;
    max-width:54px!important;
    max-height:54px!important;
    object-fit:contain!important;
  }

  .modal img,
  .admin-main img,
  .table-wrap img,
  .admin-thumb{
    max-width:74px!important;
    max-height:74px!important;
    width:auto!important;
    height:auto!important;
    object-fit:contain!important;
  }
}

@media(max-width:480px){
  .hero-with-logo{
    grid-template-columns:64px minmax(0,1fr)!important;
    gap:12px!important;
    padding:16px!important;
  }
  .hero-with-logo .public-logo-link,
  .hero-with-logo .public-logo-link img,
  .public-logo-link img{
    width:64px!important;
    height:64px!important;
    max-width:64px!important;
    max-height:64px!important;
  }
  .home-member-cta{grid-template-columns:48px minmax(0,1fr)!important}
  .home-member-cta>img,.home-member-cta img{
    width:48px!important;height:48px!important;min-width:48px!important;min-height:48px!important;max-width:48px!important;max-height:48px!important
  }
  .sponsor-box,
  .sponsor-box-with-photo,
  .sponsor-pill{grid-template-columns:48px minmax(0,1fr)!important;padding:10px!important}
  .sponsor-box img,
  .sponsor-box>img,
  .sponsor-feature-photo,
  .sponsor-pill-photo{
    width:48px!important;height:48px!important;min-width:48px!important;min-height:48px!important;max-width:48px!important;max-height:48px!important
  }
  .world-prize-photo,
  .home-prizes-layout .world-prize-photo{
    max-width:170px!important;
    max-height:170px!important;
  }
}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.79
   QR permanente visible en la cabecera pública de la home. */
.hero-with-qr{
  display:grid!important;
  grid-template-columns:140px minmax(0,1fr) 150px!important;
  gap:22px!important;
  align-items:center!important;
}
.public-hero-qr{
  display:grid!important;
  place-items:center!important;
  gap:6px!important;
  justify-self:end!important;
  text-decoration:none!important;
  color:var(--muted)!important;
  font-size:12px!important;
  font-weight:800!important;
  line-height:1!important;
  min-width:0!important;
}
.public-hero-qr img{
  display:block!important;
  width:150px!important;
  height:150px!important;
  max-width:150px!important;
  max-height:150px!important;
  object-fit:contain!important;
  background:#fff!important;
  border:1px solid var(--line)!important;
  border-radius:18px!important;
  padding:8px!important;
  box-shadow:0 10px 24px rgba(0,0,0,.08)!important;
}
@media(max-width:900px){
  .hero-with-qr{
    grid-template-columns:96px minmax(0,1fr) 104px!important;
    gap:14px!important;
    padding:18px!important;
    text-align:left!important;
  }
  .hero-with-qr .public-logo-link,
  .hero-with-qr .public-logo-link img{
    width:96px!important;
    height:96px!important;
    max-width:96px!important;
    max-height:96px!important;
  }
  .public-hero-qr img{
    width:104px!important;
    height:104px!important;
    max-width:104px!important;
    max-height:104px!important;
    padding:5px!important;
    border-radius:14px!important;
  }
  .public-hero-qr span{font-size:11px!important}
}
@media(max-width:560px){
  .hero-with-qr{
    grid-template-columns:72px minmax(0,1fr)!important;
    grid-template-areas:"logo copy" "qr qr"!important;
    gap:12px!important;
    text-align:left!important;
  }
  .hero-with-qr .public-logo-link{grid-area:logo!important}
  .hero-with-qr .hero-copy{grid-area:copy!important}
  .hero-with-qr .public-hero-qr{
    grid-area:qr!important;
    justify-self:center!important;
    margin-top:4px!important;
  }
  .hero-with-qr .public-logo-link,
  .hero-with-qr .public-logo-link img{
    width:72px!important;
    height:72px!important;
    max-width:72px!important;
    max-height:72px!important;
  }
  .hero-with-qr .hero-copy h1{
    font-size:clamp(27px,8.5vw,38px)!important;
  }
  .public-hero-qr img{
    width:150px!important;
    height:150px!important;
    max-width:150px!important;
    max-height:150px!important;
  }
}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.82
   Refuerzo real de móvil: evita logos/imágenes gigantes aunque vengan subidas enormes o alguna regla antigua gane por cascada. */
.public-body img{max-width:100%;height:auto}
.public-body .card,
.public-body .match-card,
.public-body .home-prizes-layout,
.public-body .sponsors-pills,
.public-body .sponsor-pill,
.public-body .home-member-cta,
.public-body .steps-member-recommendation,
.public-body .world-prize-home{min-width:0;overflow:hidden}

@media(max-width:900px){
  .hero-with-qr{grid-template-columns:74px minmax(0,1fr) 86px!important;gap:10px!important;padding:14px!important;border-radius:20px!important}
  .hero-with-qr .public-logo-link,
  .hero-with-qr .public-logo-link img{width:74px!important;height:74px!important;max-width:74px!important;max-height:74px!important;object-fit:contain!important}
  .public-hero-qr img{width:86px!important;height:86px!important;max-width:86px!important;max-height:86px!important;padding:4px!important;border-radius:12px!important}
  .public-hero-qr span{display:none!important}
}

@media(max-width:640px){
  .public-body .site-wrap{padding:10px!important;max-width:100%!important;overflow:hidden!important}
  .hero-with-qr{grid-template-columns:58px minmax(0,1fr)!important;grid-template-areas:"logo copy"!important;gap:10px!important;padding:12px!important;text-align:left!important}
  .hero-with-qr .public-logo-link{grid-area:logo!important;width:58px!important;height:58px!important;max-width:58px!important;max-height:58px!important;overflow:hidden!important}
  .hero-with-qr .public-logo-link img{width:58px!important;height:58px!important;max-width:58px!important;max-height:58px!important;object-fit:contain!important}
  .hero-with-qr .hero-copy{grid-area:copy!important;min-width:0!important}
  .hero-with-qr .hero-copy h1{font-size:clamp(24px,7.5vw,34px)!important;line-height:1.03!important;margin:0 0 4px!important;overflow-wrap:normal!important}
  .hero-with-qr .hero-copy p{font-size:13px!important;line-height:1.25!important;margin:0!important}
  .hero-with-qr .public-hero-qr{display:none!important}

  .home-member-cta,
  .steps-member-recommendation{display:grid!important;grid-template-columns:48px minmax(0,1fr)!important;gap:10px!important;align-items:center!important;text-align:left!important;padding:12px!important}
  .home-member-cta img,
  .steps-member-recommendation img{width:48px!important;height:48px!important;min-width:48px!important;min-height:48px!important;max-width:48px!important;max-height:48px!important;object-fit:contain!important;margin:0!important;padding:0!important}
  .home-member-copy,
  .steps-member-recommendation div{min-width:0!important;overflow-wrap:anywhere!important}
  .btn-home-member,
  .steps-member-recommendation .btn{grid-column:1/-1!important;width:100%!important;justify-content:center!important}

  .home-prizes-layout{display:grid!important;grid-template-columns:1fr!important;gap:12px!important;margin-top:14px!important}
  .home-prizes-left{padding:12px!important;border-radius:18px!important}
  .home-prizes-head h3{font-size:21px!important;line-height:1.08!important;margin-top:4px!important}
  .sponsors-pills{display:grid!important;grid-template-columns:1fr!important;gap:10px!important}
  .sponsor-pill{display:grid!important;grid-template-columns:58px minmax(0,1fr)!important;gap:10px!important;align-items:center!important;padding:10px!important;border-radius:16px!important;max-width:100%!important;overflow:hidden!important}
  .sponsor-pill-photo,
  .sponsor-pill img.sponsor-pill-photo,
  .sponsor-pill > img:first-child{width:58px!important;height:58px!important;min-width:58px!important;min-height:58px!important;max-width:58px!important;max-height:58px!important;aspect-ratio:1/1!important;object-fit:cover!important;border-radius:12px!important;margin:0!important;padding:0!important;grid-column:1!important;grid-row:1!important;display:block!important}
  .sponsor-pill-logo,
  .sponsor-pill img.sponsor-pill-logo{display:none!important;width:0!important;height:0!important;max-width:0!important;max-height:0!important;overflow:hidden!important}
  .sponsor-pill-copy{grid-column:2!important;min-width:0!important;overflow:hidden!important}
  .sponsor-pill-copy strong{font-size:17px!important;line-height:1.08!important;overflow-wrap:anywhere!important}
  .sponsor-pill-copy span{font-size:14px!important;line-height:1.2!important;overflow-wrap:anywhere!important}
  .sponsor-pill-copy small{font-size:12px!important;line-height:1.25!important;overflow-wrap:anywhere!important}
  .sponsor-pill-btn{grid-column:1/-1!important;width:100%!important;justify-content:center!important;text-align:center!important;margin-top:2px!important}

  .world-prize-home{display:grid!important;grid-template-columns:1fr!important;padding:13px!important;border-radius:18px!important;text-align:left!important;max-width:100%!important;overflow:hidden!important}
  .world-prize-badge{font-size:11px!important;line-height:1.1!important;white-space:normal!important;width:auto!important;max-width:100%!important}
  .world-prize-photo,
  .home-prizes-layout .world-prize-photo{width:100%!important;max-width:150px!important;height:auto!important;max-height:150px!important;aspect-ratio:1/1!important;object-fit:cover!important;margin:8px auto 0!important;display:block!important;border-radius:14px!important}
  .world-prize-copy{min-width:0!important;overflow-wrap:anywhere!important}
  .world-prize-copy strong{font-size:20px!important;line-height:1.08!important}
  .world-prize-copy p,.world-prize-copy span{font-size:13px!important;line-height:1.28!important}
}

@media(max-width:390px){
  .hero-with-qr{grid-template-columns:48px minmax(0,1fr)!important;padding:10px!important}
  .hero-with-qr .public-logo-link,
  .hero-with-qr .public-logo-link img{width:48px!important;height:48px!important;max-width:48px!important;max-height:48px!important}
  .hero-with-qr .hero-copy h1{font-size:24px!important}
  .sponsor-pill{grid-template-columns:50px minmax(0,1fr)!important}
  .sponsor-pill-photo,
  .sponsor-pill img.sponsor-pill-photo,
  .sponsor-pill > img:first-child{width:50px!important;height:50px!important;min-width:50px!important;min-height:50px!important;max-width:50px!important;max-height:50px!important}
}


/* v1.0.89 · Enlace de patrocinadores más visible */
.top-menu-sponsor{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:10px 14px;
  border-radius:999px;
  background:linear-gradient(135deg,#f7c948,#f59e0b);
  color:#111!important;
  font-weight:900;
  box-shadow:0 10px 24px rgba(245,158,11,.28);
}
.footer-sponsor-cta{
  display:flex;
  flex-direction:column;
  gap:7px;
  max-width:330px;
  padding:16px 18px;
  border-radius:20px;
  border:1px solid rgba(245,158,11,.42);
  background:linear-gradient(135deg,rgba(255,248,220,.98),rgba(255,255,255,.94));
  box-shadow:0 16px 40px rgba(17,24,39,.12);
  color:#111827;
}
.footer-sponsor-cta .footer-sponsor-kicker{
  color:#b45309;
  font-size:.74rem;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.footer-sponsor-cta strong{
  font-size:1.02rem;
  line-height:1.15;
}
.footer-sponsor-cta span{
  color:#4b5563;
  font-size:.9rem;
  line-height:1.35;
}
.footer-sponsor-cta a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  max-width:100%;
  margin-top:2px;
  padding:11px 15px;
  border-radius:999px;
  background:#111827;
  color:#fff!important;
  font-weight:900;
  text-decoration:none;
}
.footer-sponsor-cta a::after{
  content:' →';
}
@media(max-width:720px){
  .footer.footer-org{
    gap:16px;
    align-items:stretch;
  }
  .footer-sponsor-cta{
    max-width:none;
    width:100%;
    text-align:center;
    align-items:center;
  }
  .footer-sponsor-cta a{
    width:100%;
  }
  .top-menu-sponsor{
    width:100%;
  }
}


/* =========================================================
   v1.0.92 · Pie de página: enlaces de ayuda/legales como botones
   ========================================================= */
.footer-link-buttons {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  align-items: stretch;
  width: 100%;
  margin-top: 12px;
}
.footer-link-buttons a.footer-link-button,
.footer-link-button {
  display: flex !important;
  align-items: center;
  gap: 10px;
  min-height: 58px;
  padding: 11px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, .18);
  background: rgba(255, 255, 255, .07);
  color: #fff !important;
  text-decoration: none !important;
  box-shadow: 0 10px 24px rgba(0, 0, 0, .18);
  transition: transform .16s ease, border-color .16s ease, background .16s ease, box-shadow .16s ease;
}
.footer-link-buttons a.footer-link-button:hover,
.footer-link-button:hover {
  transform: translateY(-1px);
  border-color: rgba(245, 190, 69, .55);
  background: rgba(245, 190, 69, .11);
  box-shadow: 0 14px 30px rgba(0, 0, 0, .24);
}
.footer-link-button-contact {
  border-color: rgba(245, 190, 69, .45) !important;
  background: linear-gradient(135deg, rgba(245, 190, 69, .20), rgba(255, 255, 255, .07)) !important;
}
.footer-link-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 32px;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: #f5be45;
  color: #15110b;
  font-weight: 900;
  line-height: 1;
  box-shadow: 0 8px 16px rgba(245, 190, 69, .25);
}
.footer-link-button span:last-child {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.footer-link-button strong {
  display: block;
  color: #fff;
  font-size: .92rem;
  line-height: 1.05;
  white-space: nowrap;
}
.footer-link-button small {
  display: block;
  color: rgba(255, 255, 255, .72);
  font-size: .76rem;
  line-height: 1.05;
  white-space: nowrap;
}
@media (max-width: 820px) {
  .footer-link-buttons {
    grid-template-columns: 1fr;
  }
  .footer-link-buttons a.footer-link-button,
  .footer-link-button {
    min-height: 54px;
  }
}
@media (max-width: 520px) {
  .footer-link-button strong,
  .footer-link-button small {
    white-space: normal;
  }
}

/* =========================================================
   v1.0.93 · Pie público: botones visibles sobre fondo claro
   ========================================================= */
.footer.footer-org{
  display:grid !important;
  grid-template-columns: minmax(260px,1fr) minmax(260px,330px) minmax(360px,1.2fr) !important;
  gap:18px !important;
  align-items:center !important;
  color:#3f3a34 !important;
}
.footer.footer-org .footer-logo-link{
  grid-column:1;
  grid-row:1;
  align-self:center;
}
.footer.footer-org .footer-org-text{
  grid-column:1;
  grid-row:1;
  padding-left:78px;
  min-width:0;
}
.footer-link-buttons{
  margin-top:0 !important;
  width:100% !important;
  min-width:0 !important;
}
.footer-link-buttons a.footer-link-button,
.footer-link-button{
  background:linear-gradient(135deg,#ffffff,#fff8e9) !important;
  border:1px solid rgba(217,164,65,.55) !important;
  color:#15110b !important;
  box-shadow:0 12px 28px rgba(17,24,39,.12) !important;
}
.footer-link-buttons a.footer-link-button:hover,
.footer-link-button:hover{
  background:linear-gradient(135deg,#fff4cf,#ffffff) !important;
  border-color:rgba(217,164,65,.9) !important;
  box-shadow:0 16px 34px rgba(17,24,39,.16) !important;
}
.footer-link-button-contact{
  background:linear-gradient(135deg,#111827,#2c2418) !important;
  border-color:rgba(217,164,65,.85) !important;
  color:#fff !important;
}
.footer-link-button-contact .footer-link-icon{
  background:#f5be45 !important;
  color:#15110b !important;
}
.footer-link-icon{
  background:#d9a441 !important;
  color:#15110b !important;
  flex:0 0 34px !important;
  width:34px !important;
  height:34px !important;
}
.footer-link-button strong{
  color:#15110b !important;
  font-size:.96rem !important;
  font-weight:950 !important;
}
.footer-link-button small{
  color:#5f564b !important;
  font-size:.78rem !important;
  font-weight:700 !important;
}
.footer-link-button-contact strong,
.footer-link-button-contact small{
  color:#fff !important;
}
@media(max-width:980px){
  .footer.footer-org{
    grid-template-columns:1fr !important;
    align-items:stretch !important;
  }
  .footer.footer-org .footer-logo-link,
  .footer.footer-org .footer-org-text{
    grid-column:auto;
    grid-row:auto;
  }
  .footer.footer-org .footer-org-text{
    padding-left:0;
  }
  .footer.footer-org .footer-logo-link img{
    margin:0 auto 8px;
  }
  .footer-link-buttons{
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  }
}
@media(max-width:680px){
  .footer-link-buttons{
    grid-template-columns:1fr !important;
  }
  .footer-link-buttons a.footer-link-button,
  .footer-link-button{
    justify-content:flex-start !important;
    min-height:58px !important;
  }
}

/* =========================================================
   v1.0.94 · Pie de página: reorganización completa en escritorio
   ========================================================= */
.footer.footer-org{
  grid-template-columns:minmax(280px,1.15fr) minmax(300px,0.95fr) !important;
  grid-template-areas:
    "org sponsor"
    "links links" !important;
  align-items:stretch !important;
  gap:20px !important;
}
.footer.footer-org .footer-logo-link,
.footer.footer-org .footer-org-text{
  grid-area:org;
}
.footer.footer-org .footer-logo-link{
  align-self:start !important;
}
.footer.footer-org .footer-org-text{
  align-self:center !important;
  padding-left:84px !important;
  max-width:420px;
}
.footer.footer-org .footer-sponsor-cta{
  grid-area:sponsor;
  max-width:none !important;
  width:100%;
  align-self:stretch;
  justify-self:stretch;
}
.footer.footer-org .footer-link-buttons{
  grid-area:links;
  grid-template-columns:repeat(3,minmax(220px,1fr)) !important;
  gap:14px !important;
  margin-top:4px !important;
}
.footer-link-buttons a.footer-link-button,
.footer-link-button{
  min-height:76px !important;
  padding:14px 16px !important;
  border-radius:18px !important;
  justify-content:flex-start !important;
}
.footer-link-button span:last-child{
  gap:4px !important;
}
.footer-link-button strong,
.footer-link-button small{
  white-space:normal !important;
}
.footer-link-button strong{
  font-size:1rem !important;
  line-height:1.08 !important;
}
.footer-link-button small{
  font-size:.82rem !important;
  line-height:1.12 !important;
}
.footer-link-button-contact{
  background:linear-gradient(135deg,#111827,#24180d) !important;
}
@media(max-width:1100px){
  .footer.footer-org{
    grid-template-columns:1fr !important;
    grid-template-areas:
      "org"
      "sponsor"
      "links" !important;
  }
  .footer.footer-org .footer-logo-link,
  .footer.footer-org .footer-org-text,
  .footer.footer-org .footer-sponsor-cta,
  .footer.footer-org .footer-link-buttons{
    grid-area:auto !important;
  }
  .footer.footer-org .footer-org-text{
    padding-left:0 !important;
    max-width:none;
  }
  .footer.footer-org .footer-logo-link img{
    margin:0 auto 8px;
  }
  .footer.footer-org .footer-link-buttons{
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  }
}
@media(max-width:760px){
  .footer.footer-org .footer-link-buttons{
    grid-template-columns:1fr !important;
  }
  .footer-link-buttons a.footer-link-button,
  .footer-link-button{
    min-height:62px !important;
  }
}

/* =========================================================
   v1.0.95 · Pie de página: logo Aínsa Sound y botones legibles
   ========================================================= */
.footer.footer-org .footer-ainsa-sound-logo img{
  width:96px !important;
  height:auto !important;
  max-width:120px !important;
  max-height:82px !important;
  object-fit:contain !important;
  background:#fff !important;
  border-radius:14px !important;
  padding:8px !important;
  box-shadow:0 10px 24px rgba(17,24,39,.10) !important;
}
.footer.footer-org .footer-org-text{
  padding-left:124px !important;
}
.footer-link-buttons a.footer-link-button,
.footer-link-buttons a.footer-link-button.footer-link-button-contact,
.footer-link-button,
.footer-link-button.footer-link-button-contact{
  background:linear-gradient(135deg,#ffffff,#fff8e9) !important;
  border:1px solid rgba(217,164,65,.72) !important;
  color:#15110b !important;
  box-shadow:0 12px 28px rgba(17,24,39,.12) !important;
}
.footer-link-buttons a.footer-link-button:hover,
.footer-link-buttons a.footer-link-button.footer-link-button-contact:hover,
.footer-link-button:hover,
.footer-link-button.footer-link-button-contact:hover{
  background:linear-gradient(135deg,#fff1c4,#ffffff) !important;
  border-color:rgba(217,164,65,1) !important;
  color:#15110b !important;
}
.footer-link-buttons a.footer-link-button .footer-link-icon,
.footer-link-button .footer-link-icon,
.footer-link-buttons a.footer-link-button.footer-link-button-contact .footer-link-icon,
.footer-link-button.footer-link-button-contact .footer-link-icon{
  background:#d9a441 !important;
  color:#15110b !important;
}
.footer-link-buttons a.footer-link-button strong,
.footer-link-buttons a.footer-link-button small,
.footer-link-button strong,
.footer-link-button small,
.footer-link-buttons a.footer-link-button.footer-link-button-contact strong,
.footer-link-buttons a.footer-link-button.footer-link-button-contact small,
.footer-link-button.footer-link-button-contact strong,
.footer-link-button.footer-link-button-contact small{
  color:#15110b !important;
  opacity:1 !important;
  text-shadow:none !important;
}
.footer-link-buttons a.footer-link-button small,
.footer-link-button small,
.footer-link-buttons a.footer-link-button.footer-link-button-contact small,
.footer-link-button.footer-link-button-contact small{
  color:#5f564b !important;
}
@media(max-width:1100px){
  .footer.footer-org .footer-org-text{
    padding-left:0 !important;
    text-align:center;
  }
  .footer.footer-org .footer-ainsa-sound-logo img{
    margin:0 auto 8px !important;
  }
}


/* =========================================================
   v1.0.96 · Pie premium reorganizado
   ========================================================= */
.footer.footer-premium{
  display:grid !important;
  grid-template-columns:1.05fr 1fr;
  gap:18px !important;
  align-items:stretch !important;
  padding:8px 0 12px !important;
}
.footer.footer-premium .footer-card{
  background:#fffdf8;
  border:1px solid #e7c274;
  border-radius:24px;
  box-shadow:0 14px 34px rgba(26,20,12,.08);
  padding:20px 22px;
}
.footer.footer-premium .footer-about-card{
  display:grid;
  grid-template-columns:92px 1fr;
  gap:18px;
  align-items:center;
}
.footer.footer-premium .footer-ainsa-sound-logo{
  width:92px;
  height:92px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:18px;
  background:#fff;
  border:1px solid #eee3ce;
}
.footer.footer-premium .footer-ainsa-sound-logo img{
  width:72px !important;
  height:auto !important;
  max-width:72px !important;
  max-height:72px !important;
  margin:0 !important;
}
.footer.footer-premium .footer-org-text{
  min-width:0;
  max-width:none !important;
  padding:0 !important;
  line-height:1.45;
  color:#4f463f;
}
.footer-card-kicker,
.footer-sponsor-kicker{
  display:block;
  margin-bottom:8px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#b86d08;
}
.footer.footer-premium .footer-org-text strong,
.footer.footer-premium .footer-sponsor-cta strong{
  display:block;
  font-size:1.34rem !important;
  line-height:1.15 !important;
  color:#121212 !important;
  margin-bottom:6px;
}
.footer.footer-premium .footer-org-text a{
  color:#8c5306;
  font-weight:700;
}
.footer.footer-premium .footer-sponsor-cta{
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.footer.footer-premium .footer-sponsor-cta span{
  color:#544b44 !important;
  font-size:1.02rem;
  line-height:1.5;
}
.footer.footer-premium .footer-sponsor-cta a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:14px;
  align-self:flex-start;
  background:linear-gradient(135deg,#0f172a,#1f2937);
  color:#fff !important;
  text-decoration:none;
  font-weight:900;
  border-radius:999px;
  padding:13px 18px;
}
.footer.footer-premium .footer-links-card{
  grid-column:1 / -1;
}
.footer.footer-premium .footer-link-buttons{
  display:grid !important;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px !important;
  margin:0 !important;
}
.footer.footer-premium .footer-link-button,
.footer.footer-premium .footer-link-button.footer-link-button-contact{
  min-height:82px;
  display:flex !important;
  align-items:center;
  gap:14px;
  padding:16px 18px !important;
  border-radius:18px !important;
  border:1px solid #ead5a7 !important;
  background:#fffaf0 !important;
  color:#151515 !important;
  text-decoration:none;
  box-shadow:none !important;
}
.footer.footer-premium .footer-link-button:hover,
.footer.footer-premium .footer-link-button.footer-link-button-contact:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 22px rgba(0,0,0,.08) !important;
}
.footer.footer-premium .footer-link-button-contact{
  background:linear-gradient(135deg,#1d2431,#2a1d11) !important;
  border-color:#2f2520 !important;
}
.footer.footer-premium .footer-link-button-contact strong,
.footer.footer-premium .footer-link-button-contact small{
  color:#fff !important;
}
.footer.footer-premium .footer-link-icon{
  width:38px !important;
  height:38px !important;
  flex:0 0 38px !important;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#efbd3e !important;
  color:#111 !important;
  font-weight:900;
}
.footer.footer-premium .footer-link-button span:last-child{
  display:flex;
  flex-direction:column;
  gap:3px;
}
.footer.footer-premium .footer-link-button strong,
.footer.footer-premium .footer-link-button small{
  color:#111 !important;
  white-space:normal !important;
  line-height:1.18 !important;
  opacity:1 !important;
}
.footer.footer-premium .footer-link-button strong{font-size:1.05rem !important;font-weight:900 !important;}
.footer.footer-premium .footer-link-button small{font-size:.88rem !important;font-weight:700 !important;color:#5c534b !important;}
@media(max-width:920px){
  .footer.footer-premium{grid-template-columns:1fr !important;}
  .footer.footer-premium .footer-links-card{grid-column:auto;}
}
@media(max-width:760px){
  .footer.footer-premium .footer-about-card{grid-template-columns:1fr; text-align:center;}
  .footer.footer-premium .footer-ainsa-sound-logo{margin:0 auto;}
  .footer.footer-premium .footer-sponsor-cta a{align-self:center;}
  .footer.footer-premium .footer-link-buttons{grid-template-columns:1fr !important;}
}

/* =========================================================
   v1.0.97 · Footer organiza: evitar solape logo/texto
   ========================================================= */
.footer.footer-premium .footer-about-card{
  display:grid !important;
  grid-template-columns:120px minmax(0,1fr) !important;
  column-gap:24px !important;
  row-gap:12px !important;
  align-items:center !important;
  text-align:left !important;
}
.footer.footer-premium .footer-about-card > .footer-logo-link,
.footer.footer-premium .footer-about-card > .footer-ainsa-sound-logo{
  grid-area:auto !important;
  grid-column:1 !important;
  grid-row:1 !important;
  justify-self:center !important;
  align-self:center !important;
  margin:0 !important;
  position:relative !important;
  z-index:1 !important;
}
.footer.footer-premium .footer-about-card > .footer-org-text{
  grid-area:auto !important;
  grid-column:2 !important;
  grid-row:1 !important;
  align-self:center !important;
  justify-self:stretch !important;
  padding:0 !important;
  margin:0 !important;
  max-width:none !important;
  min-width:0 !important;
  position:relative !important;
  z-index:2 !important;
}
.footer.footer-premium .footer-ainsa-sound-logo{
  width:108px !important;
  height:108px !important;
  flex:0 0 108px !important;
}
.footer.footer-premium .footer-ainsa-sound-logo img{
  width:88px !important;
  max-width:88px !important;
  height:auto !important;
  max-height:88px !important;
  object-fit:contain !important;
}
.footer.footer-premium .footer-org-text strong{
  margin-top:0 !important;
}
@media(max-width:760px){
  .footer.footer-premium .footer-about-card{
    grid-template-columns:1fr !important;
    text-align:center !important;
  }
  .footer.footer-premium .footer-about-card > .footer-logo-link,
  .footer.footer-premium .footer-about-card > .footer-ainsa-sound-logo,
  .footer.footer-premium .footer-about-card > .footer-org-text{
    grid-column:1 !important;
    grid-row:auto !important;
    justify-self:center !important;
  }
}

/* =========================================================
   v1.0.100 · Estado público: estadísticas potentes antes del ranking
   ========================================================= */
.estado-stats-pro{
  overflow:hidden;
  position:relative;
}
.estado-stats-pro::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 14% 12%, rgba(239,189,62,.18), transparent 32%),
    radial-gradient(circle at 86% 0%, rgba(255,255,255,.42), transparent 28%);
}
.estado-stats-pro > *{
  position:relative;
  z-index:1;
}
.estado-section-head-big h2{
  margin-bottom:6px;
}
.stats-highlight-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin:20px 0;
}
.stats-highlight-card{
  border:1px solid rgba(184,109,8,.28);
  border-radius:20px;
  padding:18px;
  background:linear-gradient(145deg,#fffdf8,#fff7e8);
  box-shadow:0 14px 30px rgba(26,20,12,.07);
}
.stats-highlight-card span{
  display:block;
  margin-bottom:8px;
  color:#7b5d2d;
  font-weight:900;
  font-size:.78rem;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.stats-highlight-card strong{
  display:block;
  color:#111827;
  font-size:1.35rem;
  line-height:1.1;
}
.stats-split-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:18px;
}
.stats-panel{
  border-radius:24px;
  padding:22px;
  border:1px solid rgba(231,194,116,.9);
  box-shadow:0 18px 38px rgba(20,15,7,.08);
}
.stats-admin-panel{
  background:linear-gradient(145deg,#161616,#30281f);
  color:#fff;
  border-color:rgba(239,189,62,.42);
}
.stats-user-panel{
  background:linear-gradient(145deg,#ffffff,#fff9ec);
}
.stats-panel-title{
  display:flex;
  gap:14px;
  align-items:flex-start;
  margin-bottom:20px;
}
.stats-panel-icon{
  width:46px;
  height:46px;
  border-radius:15px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#efbd3e;
  color:#111;
  font-size:1.35rem;
  flex:0 0 46px;
  box-shadow:0 12px 24px rgba(239,189,62,.24);
}
.stats-panel-title h3{
  margin:0 0 4px;
  font-size:1.28rem;
}
.stats-panel-title p{
  margin:0;
  color:inherit;
  opacity:.72;
  line-height:1.35;
}
.admin-match-score{
  display:grid;
  grid-template-columns:auto 1fr auto auto 1fr;
  align-items:center;
  gap:10px;
  margin:14px 0 18px;
  padding:18px;
  border-radius:20px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
}
.admin-match-score strong{
  font-size:3rem;
  line-height:1;
  color:#fff;
}
.admin-match-score span{
  font-weight:900;
  color:#f7df99;
}
.admin-match-score em{
  font-style:normal;
  color:#efbd3e;
  font-weight:900;
  font-size:2rem;
}
.admin-match-meta{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin-bottom:18px;
}
.admin-match-meta div{
  padding:12px;
  border-radius:16px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.1);
}
.admin-match-meta span{
  display:block;
  margin-bottom:4px;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#d8b65a;
  font-weight:900;
}
.admin-match-meta strong{
  color:#fff;
  font-size:.95rem;
}
.goal-timeline h4,
.minute-buckets h4{
  margin:0 0 10px;
  font-size:1rem;
}
.goal-timeline-row{
  display:grid;
  grid-template-columns:52px 74px 1fr;
  gap:10px;
  align-items:center;
  padding:10px 0;
  border-top:1px solid rgba(255,255,255,.1);
}
.goal-minute{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  min-width:42px;
  min-height:32px;
  border-radius:999px;
  background:#efbd3e;
  color:#111;
  font-weight:900;
}
.goal-timeline-row strong{
  color:#fff;
}
.goal-timeline-row em{
  color:#f8eed4;
  font-style:normal;
}
.empty-mini{
  margin:0;
  color:#766b5d;
  font-weight:700;
}
.stats-admin-panel .empty-mini{
  color:#e8dcc7;
  opacity:.8;
}
.sign-bars{
  display:grid;
  gap:13px;
}
.sign-bar-row{
  display:grid;
  grid-template-columns:minmax(120px,1.1fr) minmax(120px,1fr) 44px;
  gap:12px;
  align-items:center;
  padding:12px;
  border-radius:16px;
  background:#fff;
  border:1px solid #efe0bf;
}
.sign-bar-row strong,
.sign-bar-row span{
  display:block;
}
.sign-bar-row strong{
  font-size:1rem;
  color:#141414;
}
.sign-bar-row span{
  color:#7b7062;
  font-size:.85rem;
  font-weight:800;
}
.sign-bar-row em{
  text-align:right;
  color:#b86d08;
  font-style:normal;
  font-weight:900;
}
.progress{
  height:12px;
  border-radius:999px;
  background:#f0e6d2;
  overflow:hidden;
}
.progress span{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,#d99314,#efbd3e);
}
.minute-buckets{
  margin-top:22px;
}
.minute-bucket-grid{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:8px;
  align-items:end;
  padding:14px 10px 10px;
  border-radius:18px;
  background:#fff;
  border:1px solid #efe0bf;
}
.minute-bucket{
  display:flex;
  flex-direction:column-reverse;
  align-items:center;
  gap:6px;
  min-height:110px;
}
.minute-bucket i{
  display:block;
  width:100%;
  max-width:28px;
  min-height:8px;
  border-radius:10px 10px 4px 4px;
  background:linear-gradient(180deg,#efbd3e,#b86d08);
}
.minute-bucket strong{
  font-size:1rem;
  color:#111;
}
.minute-bucket span{
  font-size:.75rem;
  color:#786d5e;
  font-weight:900;
}
.stats-lists-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin-top:18px;
}
.stats-list-card{
  background:#fff;
  border:1px solid #ead7ad;
  border-radius:22px;
  padding:18px;
  box-shadow:0 12px 28px rgba(26,20,12,.06);
}
.stats-list-card h3{
  margin:0 0 14px;
  font-size:1.08rem;
}
.stat-bar-line{
  display:grid;
  gap:8px;
  padding:11px 0;
  border-top:1px solid #f0e5d1;
}
.stat-bar-line:first-of-type{
  border-top:0;
}
.stat-bar-line div{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:baseline;
}
.stat-bar-line strong{
  color:#111;
  line-height:1.2;
}
.stat-bar-line span{
  color:#7b7062;
  font-weight:900;
  white-space:nowrap;
}
.stat-bar-line i{
  display:block;
  height:10px;
  border-radius:999px;
  background:#f1e7d4;
  overflow:hidden;
}
.stat-bar-line b{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,#b86d08,#efbd3e);
}
@media(max-width:980px){
  .stats-highlight-grid,
  .stats-split-grid,
  .stats-lists-grid{
    grid-template-columns:1fr 1fr;
  }
  .stats-split-grid{
    grid-template-columns:1fr;
  }
}
@media(max-width:680px){
  .stats-highlight-grid,
  .stats-lists-grid{
    grid-template-columns:1fr;
  }
  .admin-match-score{
    grid-template-columns:1fr auto 1fr;
    text-align:center;
  }
  .admin-match-score span:nth-of-type(1),
  .admin-match-score span:nth-of-type(2){
    grid-row:2;
  }
  .admin-match-meta,
  .minute-bucket-grid{
    grid-template-columns:1fr 1fr;
  }
  .sign-bar-row{
    grid-template-columns:1fr;
  }
  .sign-bar-row em{
    text-align:left;
  }
  .goal-timeline-row{
    grid-template-columns:52px 1fr;
  }
  .goal-timeline-row em{
    grid-column:2;
  }
}


/* =========================================================
   v1.0.101 · Histórico de ganadores en estadísticas
   ========================================================= */
.winners-history-card{
  margin-top:22px;
  padding:22px;
  border-radius:26px;
  border:1px solid rgba(220,171,70,.35);
  background:linear-gradient(135deg,#fffaf0,#ffffff 55%,#fff7df);
  box-shadow:0 18px 48px rgba(30,24,12,.08);
}
.winners-history-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:18px;
  margin-bottom:18px;
}
.winners-history-head h3{margin:.1rem 0 .35rem;font-size:1.45rem;}
.current-winner-pill{
  min-width:260px;
  padding:16px 18px;
  border-radius:22px;
  background:linear-gradient(135deg,#111827,#31200f);
  color:#fff;
  box-shadow:0 14px 30px rgba(17,24,39,.20);
}
.current-winner-pill span,
.current-winner-pill small{display:block;color:rgba(255,255,255,.78);font-weight:800;}
.current-winner-pill strong{display:block;margin:5px 0;font-size:1.16rem;line-height:1.16;color:#fff;}
.winners-history-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.winner-history-item{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:16px;
  border-radius:22px;
  background:#fff;
  border:1px solid rgba(199,145,46,.25);
  box-shadow:0 12px 28px rgba(32,24,9,.07);
}
.winner-match-meta span,
.winner-person span{
  display:block;
  font-size:.78rem;
  line-height:1.1;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#b67609;
}
.winner-match-meta strong,
.winner-person strong{
  display:block;
  margin-top:4px;
  color:#111827;
  font-size:1.02rem;
  line-height:1.18;
}
.winner-person small{display:block;margin-top:4px;color:#5f564d;font-weight:800;}
.winner-tie-list{display:flex;flex-direction:column;gap:4px;}
.winner-tie-list span{display:block;padding:6px 8px;border-radius:10px;background:#fff7df;color:#4c3920;font-weight:800;font-size:.82rem;}
.winner-history-item a{margin-top:auto;color:#8a5208;font-weight:900;text-decoration:none;}
.winner-history-item a:hover{text-decoration:underline;}
@media(max-width:1100px){.winners-history-grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media(max-width:720px){
  .winners-history-head{flex-direction:column;}
  .current-winner-pill{min-width:0;width:100%;}
  .winners-history-grid{grid-template-columns:1fr;}
}


/* =========================================================
   v1.0.102 · Edición manual de ganadores en administración
   ========================================================= */
.admin-winner-editor{
  border:1px solid #e4c06f;
  background:linear-gradient(180deg,#fffdf7,#fffaf0);
}
.current-admin-winner-box{
  display:flex;
  flex-direction:column;
  gap:4px;
  border-radius:18px;
  padding:18px 20px;
  margin:16px 0;
  background:#111827;
  color:#fff;
  box-shadow:0 14px 32px rgba(17,24,39,.16);
}
.current-admin-winner-box span,
.current-admin-winner-box small{
  color:rgba(255,255,255,.78);
  font-weight:800;
}
.current-admin-winner-box strong{
  color:#fff;
  font-size:1.32rem;
  line-height:1.15;
}
.admin-winner-editor select[multiple]{
  min-height:190px;
  padding:10px;
}
.admin-winner-editor select[multiple] option{
  padding:8px 10px;
}


/* =========================================================
   v1.0.103 · Modal edición de porra + ganador integrado
   ========================================================= */
.admin-modal-backdrop{
  position:fixed;
  inset:0;
  z-index:9999;
  background:rgba(13,16,23,.72);
  backdrop-filter:blur(5px);
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding:36px 16px;
  overflow:auto;
}
.admin-modal{
  width:min(1180px,100%);
  background:#fffdf8;
  border:1px solid rgba(231,194,116,.85);
  border-radius:28px;
  box-shadow:0 32px 90px rgba(0,0,0,.35);
  overflow:hidden;
}
.admin-modal-head{
  position:sticky;
  top:0;
  z-index:5;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:22px 26px;
  background:linear-gradient(135deg,#111827,#2a1c0a);
  color:#fff;
}
.admin-modal-head h2{margin:0;color:#fff;}
.admin-modal-head .small-label{color:#f5c75a;}
.admin-modal-body{
  display:grid;
  gap:18px;
  padding:22px;
}
.modal-section{
  background:#fff;
  border:1px solid #ecd8ad;
  border-radius:22px;
  padding:20px;
  box-shadow:0 10px 26px rgba(29,22,12,.06);
}
.modal-section > h3:first-child{margin-top:0;}
.compact-head{margin-bottom:12px;}
.current-admin-winner-box.is-empty strong{color:#7b6b5a;}
.winner-reset-form{margin-top:10px;}
@media(max-width:760px){
  .admin-modal-backdrop{padding:12px 8px;}
  .admin-modal{border-radius:20px;}
  .admin-modal-head{padding:16px;align-items:flex-start;}
  .admin-modal-body{padding:12px;}
  .modal-section{padding:14px;border-radius:18px;}
}

/* =========================================================
   v1.0.104 · Ganador real y ganador visible
   ========================================================= */
.winner-real-visible-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin:14px 0;
}
.winner-visible-box{
  border-color:#efbd3e !important;
  background:linear-gradient(180deg,#fffdf6,#fff7e3) !important;
}
.winner-edit-grid{
  align-items:start;
}
.winner-label-fields{
  display:grid;
  gap:12px;
}
.winner-label-fields input[readonly]{
  background:#f6f1e7;
  color:#4b4237;
  border-style:dashed;
  font-weight:800;
}
@media(max-width:760px){
  .winner-real-visible-grid{
    grid-template-columns:1fr;
  }
}


/* =========================================================
   v1.0.105 · Administración: estadísticas completas porra arriba y visitas debajo
   ========================================================= */
.admin-stats-selector-card{border:1px solid rgba(205,148,47,.28)}
.admin-stats-select-form{max-width:520px}
.admin-porra-stats-hero{
  background:linear-gradient(135deg,#fff8e6,#fffdf8 58%,#f7ead3);
  border:1px solid #e7c274;
  box-shadow:0 18px 42px rgba(45,33,12,.08);
}
.admin-porra-stats-head h2{font-size:clamp(1.7rem,2.4vw,2.6rem)}
.admin-porra-kpi-grid{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:14px;
  margin-top:18px;
}
.admin-kpi-card{
  background:#fff;
  border:1px solid #ead7ab;
  border-radius:20px;
  padding:16px 14px;
  box-shadow:0 10px 24px rgba(48,32,8,.06);
}
.admin-kpi-card span,
.admin-kpi-card small{display:block;color:#6b5f51;font-weight:800;font-size:.82rem;line-height:1.2}
.admin-kpi-card strong{display:block;margin:8px 0 5px;font-size:clamp(1.35rem,2vw,2rem);line-height:1.05;color:#171411;word-break:break-word}
.admin-porra-stats-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:18px;
  margin:18px 0;
}
.admin-stat-panel{
  background:#fffdf8;
  border:1px solid #e9d2a0;
}
.admin-stat-panel-title{
  display:flex;
  gap:14px;
  align-items:flex-start;
  margin-bottom:16px;
}
.admin-stat-panel-icon{
  width:46px;height:46px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;
  background:#fff0c8;font-size:1.45rem;flex:0 0 46px;
}
.admin-stat-panel-title h2{margin:.1rem 0 .25rem;font-size:1.35rem}
.admin-match-big-score{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  gap:14px;
  align-items:center;
  margin:14px 0 18px;
}
.admin-match-big-score div{
  background:linear-gradient(180deg,#161616,#2d261d);
  border-radius:22px;
  color:#fff;
  padding:16px;
  text-align:center;
}
.admin-match-big-score span{display:block;text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;opacity:.8;font-weight:900}
.admin-match-big-score strong{display:block;font-size:2.7rem;line-height:1;font-weight:950}
.admin-match-big-score em{font-style:normal;font-weight:950;font-size:2rem;color:#c08318}
.admin-real-meta-grid,.admin-vote-highlight-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin:12px 0;
}
.admin-real-meta-grid div,.admin-vote-highlight-grid div{
  background:#fff7e6;
  border:1px solid #ecd2a0;
  border-radius:16px;
  padding:12px;
}
.admin-real-meta-grid span,.admin-vote-highlight-grid span{display:block;color:#736756;font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.05em}
.admin-real-meta-grid strong,.admin-vote-highlight-grid strong{display:block;color:#1d1a16;font-size:1.02rem;margin-top:5px;line-height:1.18}
.admin-goal-timeline h3,.admin-minute-buckets h3{font-size:1.05rem;margin:16px 0 10px;color:#171411}
.admin-goal-row{
  display:grid;
  grid-template-columns:52px 76px 1fr;
  gap:10px;
  align-items:center;
  border:1px solid #f0dfbd;
  background:#fff;
  border-radius:14px;
  padding:10px 12px;
  margin:8px 0;
}
.admin-goal-row span{font-weight:950;color:#b86d08}
.admin-goal-row strong{font-weight:950;color:#1f1d1a}
.admin-goal-row em{font-style:normal;color:#5f554b}
.admin-sign-bars{display:grid;gap:12px;margin-top:14px}
.admin-sign-row{
  display:grid;
  grid-template-columns:minmax(130px,1fr) 1.4fr 48px;
  gap:12px;
  align-items:center;
}
.admin-sign-row strong,.admin-sign-row span{display:block;line-height:1.15}
.admin-sign-row strong{font-size:.95rem;color:#171411}
.admin-sign-row span,.admin-sign-row em{font-size:.82rem;color:#655c52;font-weight:800;font-style:normal}
.admin-sign-row i,.admin-stat-bar-line i{
  display:block;height:12px;border-radius:999px;background:#f2dfb8;overflow:hidden;
}
.admin-sign-row b,.admin-stat-bar-line b{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#e0a128,#111827)}
.admin-minute-bucket-grid{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:8px;
  align-items:end;
}
.admin-minute-bucket{
  min-height:120px;
  background:#fff;
  border:1px solid #ead8ad;
  border-radius:14px;
  padding:10px 7px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
  gap:5px;
  text-align:center;
}
.admin-minute-bucket i{display:block;width:22px;min-height:8px;border-radius:999px 999px 4px 4px;background:linear-gradient(180deg,#111827,#e0a128)}
.admin-minute-bucket strong{font-size:1.1rem;color:#111}
.admin-minute-bucket span{font-size:.76rem;font-weight:900;color:#6c5f4f}
.admin-stat-lists-grid{
  grid-template-columns:repeat(4,minmax(0,1fr));
  margin:18px 0;
}
.admin-stat-list-card{
  background:#fffdf8;
  border:1px solid #ead6a6;
  border-radius:22px;
  padding:18px;
  box-shadow:0 10px 24px rgba(48,32,8,.05);
}
.admin-stat-list-card h3{margin:0 0 12px;color:#171411;font-size:1.05rem}
.admin-stat-bars{display:grid;gap:10px}
.admin-stat-bar-line{display:grid;gap:7px}
.admin-stat-bar-line strong,.admin-stat-bar-line span{display:block;line-height:1.15}
.admin-stat-bar-line strong{font-size:.9rem;color:#171411}
.admin-stat-bar-line span{font-size:.78rem;color:#6b6256;font-weight:800}
.admin-winner-stats-card{background:linear-gradient(135deg,#fffdf8,#fff4da)}
.admin-current-winner-box{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-bottom:16px;
}
.admin-current-winner-box>div{
  background:#fff;
  border:1px solid #ead6a6;
  border-radius:20px;
  padding:16px;
}
.admin-current-winner-box span,.admin-current-winner-box small{display:block;color:#6a5f52;font-weight:800}
.admin-current-winner-box strong{display:block;margin:7px 0;color:#171411;font-size:1.2rem;line-height:1.18}
.admin-winners-strip{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:12px;
}
.admin-winners-strip article{
  background:#fff;
  border:1px solid #ecd7aa;
  border-radius:18px;
  padding:13px;
}
.admin-winners-strip span,.admin-winners-strip small{display:block;font-size:.78rem;color:#6b6256;font-weight:800;line-height:1.25}
.admin-winners-strip strong{display:block;font-size:1rem;color:#171411;margin:5px 0;line-height:1.16}
.admin-ranking-stats-card{margin-top:18px}
.admin-visit-stats-bottom{
  margin-top:24px;
  border-top:6px solid #e3af3c;
}
@media(max-width:1200px){
  .admin-porra-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
  .admin-stat-lists-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .admin-winners-strip{grid-template-columns:repeat(3,minmax(0,1fr));}
}
@media(max-width:900px){
  .admin-porra-stats-layout{grid-template-columns:1fr;}
  .admin-minute-bucket-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
}
@media(max-width:700px){
  .admin-porra-kpi-grid,.admin-stat-lists-grid,.admin-current-winner-box,.admin-winners-strip{grid-template-columns:1fr;}
  .admin-real-meta-grid,.admin-vote-highlight-grid{grid-template-columns:1fr;}
  .admin-sign-row{grid-template-columns:1fr;gap:7px;}
  .admin-goal-row{grid-template-columns:48px 1fr;}
  .admin-goal-row em{grid-column:2;}
}

/* =========================================================
   v1.0.106 · Modales admin: altura visible y scroll interno
   ========================================================= */
dialog.admin-modal,
.admin-modal{
  max-height:calc(100dvh - 24px) !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
  overscroll-behavior:contain !important;
  scrollbar-gutter:stable !important;
}
dialog.admin-modal[open]{
  margin:auto !important;
}
dialog.admin-modal .modal-head{
  position:sticky;
  top:0;
  z-index:20;
}
dialog.admin-modal .modal-close{
  flex:0 0 auto;
}
dialog.admin-modal .modal-form,
dialog.admin-modal .modal-contact-row,
dialog.admin-modal .modal-danger-zone{
  box-sizing:border-box;
}
dialog.admin-modal .modal-actions{
  position:sticky;
  bottom:0;
  z-index:15;
  padding:12px 0 2px;
  background:linear-gradient(180deg,rgba(255,253,248,0),#fffdf8 26%,#fffdf8 100%);
}
body:has(dialog.admin-modal[open]){
  overflow:hidden !important;
}
@media(max-height:760px){
  dialog.admin-modal,
  .admin-modal{
    max-height:calc(100dvh - 12px) !important;
    width:calc(100vw - 18px) !important;
  }
  dialog.admin-modal .modal-head{
    padding-top:14px !important;
    padding-bottom:14px !important;
  }
  dialog.admin-modal .modal-head h3{
    font-size:24px !important;
  }
  dialog.admin-modal .modal-contact-row{
    padding-top:12px !important;
  }
}
@media(max-width:760px){
  dialog.admin-modal,
  .admin-modal{
    max-height:calc(100dvh - 10px) !important;
    width:calc(100vw - 10px) !important;
    border-radius:18px !important;
  }
  dialog.admin-modal .modal-actions .btn,
  dialog.admin-modal .modal-danger-zone .btn{
    width:100%;
  }
}


/* =========================================================
   v1.0.111 · Enlace principal al estado de la porra en portada
   ========================================================= */
.home-status-spotlight{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:18px;
  margin:18px 0 22px;
  padding:20px 22px;
  border-radius:24px;
  background:linear-gradient(135deg,#111827 0%,#2c1b10 48%,#d9a441 130%);
  color:#fff;
  box-shadow:0 18px 42px rgba(17,24,39,.20);
  border:1px solid rgba(217,164,65,.55);
}
.home-status-spotlight-empty{
  margin-top:22px;
  grid-template-columns:1fr auto;
  text-align:left;
}
.home-status-spotlight-icon{
  width:58px;
  height:58px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:18px;
  background:rgba(255,255,255,.13);
  border:1px solid rgba(255,255,255,.22);
  font-size:1.8rem;
}
.home-status-spotlight-copy{
  min-width:0;
}
.home-status-kicker{
  display:block;
  margin-bottom:4px;
  font-size:.78rem;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#ffe7a6;
}
.home-status-spotlight strong{
  display:block;
  font-size:clamp(1.25rem,2.2vw,2rem);
  line-height:1.08;
  color:#fff;
}
.home-status-spotlight small{
  display:block;
  margin-top:7px;
  max-width:820px;
  color:rgba(255,255,255,.88);
  font-weight:650;
  line-height:1.38;
}
.btn-status-main,
.home-status-spotlight .btn-status-main{
  background:#fff !important;
  color:#17110b !important;
  border:0 !important;
  border-radius:999px !important;
  padding:14px 20px !important;
  font-size:1rem !important;
  font-weight:950 !important;
  box-shadow:0 12px 26px rgba(0,0,0,.22) !important;
  white-space:nowrap;
}
.btn-status-main:hover,
.home-status-spotlight .btn-status-main:hover{
  transform:translateY(-1px);
  background:#fff4d4 !important;
}
.home-live-strip .home-live-btn{
  font-weight:900;
  border-width:2px;
}
@media(max-width:780px){
  .home-status-spotlight,
  .home-status-spotlight-empty{
    grid-template-columns:1fr;
    text-align:center;
    gap:14px;
    padding:18px 16px;
  }
  .home-status-spotlight-icon{
    margin:0 auto;
  }
  .home-status-spotlight small{
    margin-left:auto;
    margin-right:auto;
  }
  .btn-status-main,
  .home-status-spotlight .btn-status-main{
    width:100%;
    justify-content:center;
    white-space:normal;
  }
}

/* =========================================================
   v1.0.112 · Ganador único con desempate automático
   ========================================================= */
.winner-tiebreak-notice{
  display:flex;
  flex-direction:column;
  gap:4px;
  margin:14px 0 18px;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid rgba(180,130,30,.35);
  background:#fff7df;
  color:#513b12;
  box-shadow:0 10px 22px rgba(120,80,10,.08);
}
.winner-tiebreak-notice strong{font-weight:900;color:#3f2b08;}
.winner-tiebreak-notice span{font-weight:750;line-height:1.35;}
.admin-tiebreak-notice{margin-top:12px;}
.admin-winner-editor select:not([multiple]){
  min-height:190px;
  padding:10px;
}
.admin-winner-editor select:not([multiple]) option{
  padding:8px 10px;
}

/* =========================================================
   v1.0.113 · Ganador admin + 10 más próximos
   ========================================================= */
.inline-filter-form {
    display: flex;
    align-items: flex-end;
    gap: .75rem;
    flex-wrap: wrap;
    max-width: 520px;
}
.inline-filter-form label {
    margin: 0;
    min-width: min(420px, 100%);
}
.winner-admin-summary-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, .8fr);
    gap: 1rem;
    margin-top: 1rem;
}
.winner-admin-main-card,
.winner-admin-participation-card {
    border: 1px solid rgba(17, 17, 17, .12);
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.88));
    box-shadow: 0 16px 42px rgba(17, 17, 17, .08);
    padding: 1.25rem;
}
.winner-admin-main-card h3 {
    margin: .25rem 0 .75rem;
    font-size: clamp(1.35rem, 2vw, 2.1rem);
    line-height: 1.1;
}
.winner-admin-meta,
.winner-admin-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    align-items: center;
    margin: .65rem 0;
}
.winner-admin-definition-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .6rem;
    margin: 1rem 0 0;
}
.winner-admin-definition-list div {
    border-radius: 16px;
    background: rgba(0,0,0,.035);
    padding: .7rem .8rem;
}
.winner-admin-definition-list dt {
    font-size: .72rem;
    font-weight: 800;
    color: rgba(17,17,17,.55);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: .2rem;
}
.winner-admin-definition-list dd {
    margin: 0;
    font-weight: 800;
    color: #111;
}
.winner-admin-note {
    margin-top: .85rem;
    border-left: 5px solid #f1b500;
    border-radius: 14px;
    background: rgba(241,181,0,.10);
    padding: .8rem .95rem;
}
.winner-admin-ranking-card {
    margin-top: 1rem;
}
.winner-admin-participant-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}
.winner-admin-participant-head h3 {
    margin: .2rem 0 .2rem;
    font-size: clamp(1.25rem, 2vw, 1.9rem);
}
.winner-admin-rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    min-height: 34px;
    border-radius: 999px;
    background: #111;
    color: #fff;
    font-weight: 900;
}
.winner-admin-score-big {
    min-width: 112px;
    text-align: center;
    border-radius: 22px;
    background: linear-gradient(135deg, #111, #333);
    color: #fff;
    font-size: 2.35rem;
    font-weight: 950;
    padding: .65rem .8rem;
    line-height: 1;
}
.winner-admin-score-big span {
    display: block;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    margin-top: .2rem;
    opacity: .82;
}
.winner-admin-breakdown-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: .7rem;
    margin: 1rem 0;
}
.winner-admin-breakdown-grid div {
    border-radius: 16px;
    background: rgba(0,0,0,.035);
    padding: .75rem;
}
.winner-admin-breakdown-grid strong {
    display: block;
    color: rgba(17,17,17,.55);
    font-size: .74rem;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: .2rem;
}
.winner-admin-breakdown-grid span {
    font-weight: 850;
}
.winner-admin-points-list {
    display: flex;
    gap: .45rem;
    flex-wrap: wrap;
}
.winner-admin-points-list span {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: rgba(25, 135, 84, .12);
    border: 1px solid rgba(25, 135, 84, .22);
    color: #0f5132;
    font-weight: 800;
    padding: .35rem .6rem;
    font-size: .86rem;
}
.winner-admin-points-list.compact span {
    font-size: .78rem;
    padding: .28rem .48rem;
}
.winner-admin-table th,
.winner-admin-table td {
    vertical-align: top;
}
.winner-admin-table .is-tied-row td,
.winner-admin-table tr.is-tied-row td {
    background: rgba(241, 181, 0, .09);
}
.winner-admin-points-pill {
    display: inline-flex;
    min-width: 46px;
    justify-content: center;
    border-radius: 999px;
    background: #111;
    color: #fff;
    padding: .34rem .6rem;
    font-weight: 950;
}
@media (max-width: 980px) {
    .winner-admin-summary-grid,
    .winner-admin-definition-list,
    .winner-admin-breakdown-grid {
        grid-template-columns: 1fr;
    }
    .winner-admin-participant-head {
        flex-direction: column;
    }
    .winner-admin-score-big {
        width: 100%;
    }
}
@media (max-width: 720px) {
    .inline-filter-form,
    .inline-filter-form label {
        width: 100%;
        max-width: 100%;
    }
    .winner-admin-main-card,
    .winner-admin-participation-card {
        padding: 1rem;
        border-radius: 18px;
    }
}

/* =========================================================
   v1.0.114 · Informe dinámico para participantes
   ========================================================= */
.winner-admin-report-card {
    margin-top: 1rem;
    border: 2px solid rgba(241, 181, 0, .35);
    background: linear-gradient(180deg, rgba(255, 250, 232, .96), rgba(255,255,255,.96));
}
.winner-admin-report-subject {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
    align-items: center;
    border-radius: 16px;
    background: rgba(0,0,0,.04);
    padding: .75rem .9rem;
    margin: .8rem 0;
}
.winner-admin-report-subject strong {
    color: rgba(17,17,17,.62);
    text-transform: uppercase;
    font-size: .76rem;
    letter-spacing: .05em;
}
.winner-admin-report-subject span {
    color: #111;
    font-weight: 900;
}
.winner-admin-report-textarea {
    width: 100%;
    min-height: 430px;
    max-height: 70vh;
    overflow: auto;
    resize: vertical;
    border: 1px solid rgba(17,17,17,.16);
    border-radius: 18px;
    background: #fff;
    color: #111;
    padding: 1rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
    font-size: .92rem;
    line-height: 1.55;
    box-shadow: inset 0 2px 12px rgba(0,0,0,.045);
}
.winner-admin-report-actions {
    display: flex;
    gap: .6rem;
    align-items: center;
    flex-wrap: wrap;
    margin-top: .85rem;
}
.copy-status {
    font-size: .86rem;
    font-weight: 800;
    color: #0f5132;
}
.copy-status.is-error {
    color: #842029;
}
@media (max-width: 720px) {
    .winner-admin-report-textarea {
        min-height: 360px;
        font-size: .86rem;
    }
}

/* =========================================================
   v1.0.115 · Sistema de puntos visible y desglose completo
   ========================================================= */
.scoring-public-card,
.winner-admin-scoring-card {
    border: 2px solid rgba(241, 181, 0, .26);
    background: linear-gradient(180deg, rgba(255, 250, 232, .96), rgba(255,255,255,.98));
}
.scoring-rules-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .8rem;
    margin-top: 1rem;
}
.scoring-rule-card {
    border: 1px solid rgba(17,17,17,.10);
    border-radius: 18px;
    background: #fff;
    padding: .95rem;
    box-shadow: 0 10px 24px rgba(0,0,0,.045);
}
.scoring-rule-card strong {
    display: block;
    color: #111;
    font-weight: 950;
    margin-bottom: .35rem;
}
.scoring-rule-card span {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: #111;
    color: #fff;
    font-weight: 950;
    padding: .28rem .58rem;
    font-size: .86rem;
    margin-bottom: .5rem;
}
.scoring-rule-card p {
    margin: 0;
    color: rgba(17,17,17,.68);
    font-size: .9rem;
    line-height: 1.45;
}
.tiebreak-box {
    margin-top: 1rem;
    border-radius: 18px;
    background: rgba(17,17,17,.045);
    border: 1px solid rgba(17,17,17,.10);
    padding: 1rem;
}
.tiebreak-box h3 {
    margin: 0 0 .4rem;
    font-size: 1.05rem;
}
.tiebreak-box p {
    margin: 0 0 .7rem;
    color: rgba(17,17,17,.68);
}
.tiebreak-box ol {
    margin: 0;
    padding-left: 1.25rem;
}
.tiebreak-box li {
    margin: .28rem 0;
    font-weight: 700;
    color: rgba(17,17,17,.78);
}
.score-breakdown-full {
    display: grid;
    gap: .55rem;
    margin-top: 1rem;
}
.score-breakdown-row {
    border: 1px solid rgba(17,17,17,.10);
    border-radius: 14px;
    background: #fff;
    padding: .72rem .82rem;
    display: grid;
    grid-template-columns: minmax(150px, 1fr) auto;
    gap: .35rem .75rem;
    align-items: start;
}
.score-breakdown-row strong {
    color: #111;
    font-weight: 950;
}
.score-breakdown-row span {
    justify-self: end;
    border-radius: 999px;
    padding: .22rem .52rem;
    font-weight: 950;
    font-size: .82rem;
    background: rgba(17,17,17,.08);
    color: rgba(17,17,17,.76);
}
.score-breakdown-row p {
    grid-column: 1 / -1;
    margin: 0;
    font-size: .86rem;
    line-height: 1.4;
    color: rgba(17,17,17,.64);
}
.score-breakdown-row.score-status-ok {
    border-color: rgba(25,135,84,.28);
    background: rgba(25,135,84,.065);
}
.score-breakdown-row.score-status-ok span {
    background: rgba(25,135,84,.15);
    color: #0f5132;
}
.score-breakdown-row.score-status-ko {
    border-color: rgba(132,32,41,.14);
    background: rgba(132,32,41,.035);
}
.score-breakdown-row.score-status-ko span {
    background: rgba(132,32,41,.10);
    color: #842029;
}
.score-breakdown-row.score-status-neutral span {
    background: rgba(108,117,125,.14);
    color: #495057;
}
.score-breakdown-full.compact {
    gap: .32rem;
    margin-top: 0;
}
.score-breakdown-full.compact .score-breakdown-row {
    padding: .45rem .55rem;
    border-radius: 11px;
    grid-template-columns: 1fr auto;
}
.score-breakdown-full.compact .score-breakdown-row strong,
.score-breakdown-full.compact .score-breakdown-row span {
    font-size: .76rem;
}
.score-breakdown-full.compact .score-breakdown-row p {
    font-size: .72rem;
}
.public-score-breakdown {
    display: flex;
    flex-wrap: wrap;
    gap: .32rem;
    max-width: 320px;
}
.public-score-breakdown span {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: rgba(25,135,84,.12);
    color: #0f5132;
    border: 1px solid rgba(25,135,84,.20);
    padding: .25rem .48rem;
    font-size: .78rem;
    font-weight: 850;
}
@media (max-width: 980px) {
    .scoring-rules-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 680px) {
    .scoring-rules-grid {
        grid-template-columns: 1fr;
    }
    .score-breakdown-row {
        grid-template-columns: 1fr;
    }
    .score-breakdown-row span {
        justify-self: start;
    }
}

/* ==========================================================
   /porra/admin/participantes.php · Participantes globales · v1.0.118
   ========================================================== */
.participantes-metrics{margin:18px 0}.participantes-filter-form .inline-actions{margin-top:8px}.participantes-global-wrap{max-height:none}.participantes-global-table th:nth-child(1){min-width:210px}.participantes-global-table th:nth-child(2){min-width:210px}.participantes-global-table th:nth-child(5){min-width:520px}.participant-main-cell strong{font-size:15px}.participant-points-total{display:inline-flex;align-items:center;justify-content:center;min-width:48px;height:48px;border-radius:16px;background:#111;color:#fff;font-size:22px}.participantes-contact-icons{margin-bottom:6px}.participant-votes-list{display:grid;gap:8px;min-width:500px}.participant-vote-detail{border:1px solid var(--line);border-radius:16px;background:#fbf8f1;overflow:hidden}.participant-vote-detail summary{display:grid;grid-template-columns:minmax(180px,1fr) auto auto;gap:10px;align-items:center;cursor:pointer;padding:10px 12px;font-weight:800}.participant-vote-detail summary strong{white-space:nowrap}.participant-vote-detail summary em{font-style:normal;font-size:11px;border-radius:999px;padding:4px 8px;text-transform:uppercase;font-weight:900}.vote-ok{background:#e7f4ea;color:#137333}.vote-pending{background:#fff3cd;color:#664d03}.vote-detail-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:12px;border-top:1px solid var(--line);background:#fff}.vote-detail-grid>div{border:1px solid #eee5da;border-radius:12px;padding:10px;min-width:0}.vote-detail-grid code{display:block;white-space:normal;word-break:break-all;font-size:12px;color:#3f3a34}.vote-detail-grid strong{display:block;overflow-wrap:anywhere}.participant-vote-detail .btn{margin:0 12px 12px}.participantes-pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:18px}.pagination-info{color:var(--muted);font-weight:700}@media(max-width:1100px){.vote-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.participantes-global-table th:nth-child(5){min-width:420px}.participant-votes-list{min-width:420px}}@media(max-width:760px){.participantes-global-table,.participantes-global-table tbody,.participantes-global-table tr,.participantes-global-table td{display:block;width:100%}.participantes-global-table thead{display:none}.participantes-global-table tr{border:1px solid var(--line);border-radius:18px;background:#fff;margin-bottom:14px;overflow:hidden}.participantes-global-table td{border-bottom:1px solid var(--line)}.participantes-global-table td:last-child{border-bottom:0}.participant-votes-list{min-width:0}.participant-vote-detail summary{grid-template-columns:1fr;align-items:start}.vote-detail-grid{grid-template-columns:1fr}.participantes-pagination{flex-direction:column}.participant-points-total{height:42px;min-width:42px}}

/* =========================================================
   /porra/admin/participantes.php · Matriz de participantes · v1.0.119
   ========================================================= */
.participantes-filter-card{position:sticky;top:0;z-index:20;box-shadow:0 12px 28px rgba(0,0,0,.06)}
.participantes-filter-grid.grid.five{grid-template-columns:1.4fr 1.15fr 1fr .7fr auto;align-items:end}
.filter-actions-block{display:flex;gap:8px;align-items:center;justify-content:flex-end;min-height:64px}
.participantes-points-matrix-wrap{overflow:auto;max-width:100%;border:1px solid var(--line);border-radius:18px;background:#fff}
.participantes-points-matrix{min-width:1180px;border-collapse:separate;border-spacing:0;width:max-content}
.participantes-points-matrix th,.participantes-points-matrix td{vertical-align:top;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff}
.participantes-points-matrix thead th{position:sticky;top:0;z-index:7;background:#f8f3e9;box-shadow:0 1px 0 var(--line);white-space:nowrap}
.participantes-points-matrix .sticky-col{position:sticky;z-index:8;box-shadow:1px 0 0 var(--line);background:#fff}
.participantes-points-matrix thead .sticky-col{z-index:11;background:#f8f3e9}
.participantes-points-matrix .sticky-col-1{left:0;min-width:210px;max-width:260px}
.participantes-points-matrix .sticky-col-2{left:210px;min-width:230px;max-width:280px}
.participantes-points-matrix .sort-link{display:inline-flex;align-items:center;gap:4px;color:#111;text-decoration:none;font-weight:900;line-height:1.15}
.participantes-points-matrix .sort-link span{color:#8a5b21;font-weight:900;min-width:16px;text-align:left}
.participantes-points-matrix .sort-link.active{color:#8a4b00;text-decoration:underline;text-underline-offset:4px}
.participantes-points-matrix .porra-points-th{min-width:118px;max-width:150px;white-space:normal;text-align:center}
.participantes-points-matrix .porra-points-th small{display:block;margin-top:4px;color:var(--muted);font-size:10px;font-weight:800;white-space:normal}
.participantes-points-matrix .numeric-cell{text-align:center;vertical-align:middle}
.participantes-points-matrix .points-total-col{min-width:96px;text-align:center}
.participantes-points-matrix .points-total-cell{text-align:center;background:#fffaf1}
.participantes-points-matrix .points-total-cell strong{display:block;font-size:22px;line-height:1;color:#111}
.participantes-points-matrix .points-total-cell small{display:block;color:var(--muted);font-weight:800;margin-top:3px}
.participantes-points-matrix .porra-points-cell{text-align:center;vertical-align:middle;min-width:112px;background:#fff}
.participantes-points-matrix .porra-points-cell strong{display:block;font-size:20px;line-height:1;color:#111}
.participantes-points-matrix .porra-points-cell small{display:block;color:var(--muted);font-size:11px;font-weight:800;margin-top:4px}
.participantes-points-matrix .porra-points-cell em{display:inline-block;margin-top:5px;border-radius:999px;background:#fff3cd;color:#664d03;font-size:10px;font-style:normal;font-weight:900;padding:3px 6px}
.participantes-points-matrix .porra-points-cell.not-played{background:#fbf9f5;color:#b4a899}
.participantes-points-matrix .porra-points-cell.not-played span{font-size:20px;color:#c9bdaa}
.participantes-points-matrix .porra-points-cell.has-played{background:#fffdf8}
.participantes-points-matrix .last-vote-cell{min-width:150px;font-size:12px;color:var(--muted);font-weight:700;white-space:nowrap}
.participantes-points-matrix .detail-cell{min-width:170px;max-width:220px}
.participant-row-detail summary{cursor:pointer;font-weight:900;color:#8a4b00}
.participant-row-detail[open]{position:relative;z-index:4}
.participantes-points-matrix .participant-votes-list{min-width:520px;margin-top:10px}
@media(max-width:1100px){.participantes-filter-grid.grid.five{grid-template-columns:1fr 1fr}.filter-actions-block{justify-content:flex-start;min-height:auto}.participantes-points-matrix .sticky-col{position:static}.participantes-points-matrix .sticky-col-1,.participantes-points-matrix .sticky-col-2{left:auto;min-width:200px;max-width:none}.participantes-points-matrix thead th{top:0}.participantes-points-matrix{min-width:1050px}.participantes-points-matrix .participant-votes-list{min-width:420px}}
@media(max-width:760px){.participantes-filter-card{position:static}.participantes-filter-grid.grid.five{grid-template-columns:1fr}.filter-actions-block{justify-content:stretch}.filter-actions-block .btn{flex:1}.participantes-points-matrix-wrap{border-radius:14px}.participantes-points-matrix{min-width:980px}.participantes-points-matrix .porra-points-th{min-width:105px}.participantes-points-matrix .porra-points-cell{min-width:100px}}


/*
   /porra/admin · Control mínimo de comunicaciones y bloqueo · v1.0.124
*/
.contact-control-badge{display:inline-flex;margin:5px 5px 0 0;white-space:nowrap;font-size:10px;padding:4px 7px}
.contact-icons .contact-control-compact{display:inline-flex;vertical-align:middle;position:relative}
.contact-control-compact summary{list-style:none;width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:10px;background:#fff;color:#7a4a14;cursor:pointer;font-weight:900;box-shadow:0 4px 12px rgba(0,0,0,.05)}
.contact-control-compact summary::-webkit-details-marker{display:none}
.contact-control-compact[open] summary{background:#fff7e8;border-color:#d8a65a}
.contact-control-compact form{position:absolute;z-index:40;top:36px;right:0;min-width:230px;display:grid;gap:8px;padding:10px;border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:0 14px 35px rgba(0,0,0,.16)}
.modal-contact-row .contact-control-compact form{right:auto;left:0}
.contact-control-compact-scopes{display:flex;gap:10px;flex-wrap:wrap;font-size:12px;font-weight:800;color:var(--muted)}
.contact-control-compact-scopes label{display:inline-flex;align-items:center;gap:4px;margin:0}.contact-control-compact-scopes input{width:auto;margin:0}
.contact-control-compact-actions{display:grid;grid-template-columns:1fr 1fr;gap:6px}.contact-control-compact-actions .btn{font-size:11px;padding:7px 8px;min-height:32px}
@media(max-width:760px){.contact-control-compact form{right:auto;left:0}}

/* =========================================================
   v1.0.125 · Restauración de matriz de Participantes globales
   ---------------------------------------------------------
   No se añaden columnas nuevas: se mantienen Participante, Contacto,
   Votos, Validados, Suma, 001-007 y flecha de detalle. Estos overrides
   evitan que reglas antiguas ensanchen Suma y oculten columnas de porras.
========================================================= */
.participantes-points-matrix th:nth-child(3),
.participantes-points-matrix td:nth-child(3){min-width:74px;max-width:84px;text-align:center}
.participantes-points-matrix th:nth-child(4),
.participantes-points-matrix td:nth-child(4){min-width:92px;max-width:104px;text-align:center}
.participantes-points-matrix th:nth-child(5),
.participantes-points-matrix td:nth-child(5){min-width:88px!important;max-width:104px!important;text-align:center}
.participantes-points-matrix .porra-points-th{min-width:92px!important;max-width:104px!important;text-align:center}
.participantes-points-matrix .porra-points-cell{min-width:92px!important;max-width:104px!important;text-align:center}
.participantes-points-matrix .detail-toggle-th,
.participantes-points-matrix .detail-cell{min-width:54px!important;max-width:64px!important;text-align:center}
.participantes-points-matrix .detail-cell .participant-row-detail{display:inline-block}
.participantes-points-matrix .participant-votes-list{text-align:left}
.participantes-points-matrix .contact-control-compact summary{width:28px;height:28px}

/* v1.0.125 · Comunicaciones: excluidos visibles pero no enviables */
.email-excluded-card{border-color:#f0d7a4;background:#fffaf0}
.email-excluded-card .section-head{align-items:flex-start}
.email-excluded-table td:first-child{white-space:nowrap}
.email-excluded-table .badge{display:inline-flex;align-items:center;justify-content:center}

/* =========================================================
   v1.0.126 · Iconos directos y filas coloreadas por estado
   ---------------------------------------------------------
   Dos acciones visibles: no comunicaciones y bloqueo. Sin desplegable.
========================================================= */
.contact-control-icons{display:inline-flex;align-items:center;gap:5px;vertical-align:middle;margin-left:2px}
.contact-control-icons form{display:inline-flex;margin:0;padding:0}
.contact-state-icon{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid var(--line);background:#fff;color:#4b5563;cursor:pointer;font-size:14px;line-height:1;box-shadow:0 4px 12px rgba(0,0,0,.06);transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease}
.contact-state-icon:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(0,0,0,.10)}
.contact-state-no-comunicaciones{border-color:#e5c073;background:#fffaf0;color:#8a5b00}
.contact-state-no-comunicaciones.is-active{background:#f59f00;border-color:#c97b00;color:#fff;box-shadow:0 8px 18px rgba(245,159,0,.28)}
.contact-state-bloqueado{border-color:#f0b8b8;background:#fff5f5;color:#9b1c1c}
.contact-state-bloqueado.is-active{background:#d92d20;border-color:#ad1f17;color:#fff;box-shadow:0 8px 18px rgba(217,45,32,.28)}
.contact-control-badge{font-weight:900;text-transform:uppercase;letter-spacing:.02em}
.compact-table tr.contact-row-no-comunicaciones>td,
.email-preview-table tr.contact-row-no-comunicaciones>td,
.participaciones-admin-table tr.contact-row-no-comunicaciones>td,
.participantes-points-matrix tr.contact-row-no-comunicaciones>td{background:#fff3cd!important}
.compact-table tr.contact-row-bloqueado>td,
.email-preview-table tr.contact-row-bloqueado>td,
.participaciones-admin-table tr.contact-row-bloqueado>td,
.participantes-points-matrix tr.contact-row-bloqueado>td{background:#ffe0e0!important}
.compact-table tr.contact-row-no-comunicaciones>td:first-child,
.participaciones-admin-table tr.contact-row-no-comunicaciones>td:first-child,
.participantes-points-matrix tr.contact-row-no-comunicaciones>td:first-child{border-left:6px solid #f59f00!important}
.compact-table tr.contact-row-bloqueado>td:first-child,
.participaciones-admin-table tr.contact-row-bloqueado>td:first-child,
.participantes-points-matrix tr.contact-row-bloqueado>td:first-child{border-left:6px solid #d92d20!important}
.participantes-points-matrix tr.contact-row-no-comunicaciones .sticky-col,
.participantes-points-matrix tr.contact-row-bloqueado .sticky-col{box-shadow:1px 0 0 var(--line)}
.email-excluded-metrics{grid-template-columns:repeat(3,minmax(160px,1fr));margin:12px 0}
.email-excluded-metrics .metric-warning{background:#fff3cd;border-color:#f0cd71}
.email-excluded-metrics .metric-danger{background:#ffe0e0;border-color:#f0aaaa}
.email-no-send-label{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#111;color:#fff;font-size:11px;padding:4px 8px;white-space:nowrap;letter-spacing:.04em}
.email-excluded-table tr.contact-row-no-comunicaciones td:first-child{border-left:6px solid #f59f00!important}
.email-excluded-table tr.contact-row-bloqueado td:first-child{border-left:6px solid #d92d20!important}
@media(max-width:760px){.contact-state-icon{width:32px;height:32px}.email-excluded-metrics{grid-template-columns:1fr}}

/* =========================================================
   v1.0.127 · Comunicaciones: excluidos visibles, no seleccionables
   ---------------------------------------------------------
   En admin/emails.php los contactos con No notificaciones o Bloqueado
   aparecen dentro de la misma tabla, coloreados, con iconos directos,
   pero nunca se pueden marcar para envío.
========================================================= */
.email-communications-table tr.contact-row-no-comunicaciones>td:first-child{border-left:6px solid #f59f00!important}
.email-communications-table tr.contact-row-bloqueado>td:first-child{border-left:6px solid #d92d20!important}
.email-communications-table .email-send-cell{min-width:118px;white-space:nowrap;vertical-align:middle}
.email-communications-table .email-send-cell input[type="checkbox"]{width:18px;height:18px;vertical-align:middle;margin-right:6px}
.email-disabled-send{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#6b7280;color:#fff;font-size:10px;font-weight:900;padding:4px 7px;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}
.email-selection-toolbar-wide{display:flex;justify-content:space-between;gap:14px;align-items:center;flex-wrap:wrap;margin-bottom:12px;padding:10px 12px;border:1px solid var(--line);border-radius:14px;background:#fffdf8}
.email-selection-toolbar-wide strong{display:block;color:#111}
.email-selection-toolbar-wide span{display:block;color:var(--muted);font-size:12px;font-weight:700;margin-top:2px}
.email-select-all-label{display:inline-flex!important;align-items:center;gap:8px;width:auto!important;margin:0!important;font-size:13px;font-weight:900;color:#333;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 12px;white-space:nowrap}
.email-select-all-label input{width:18px!important;height:18px!important;margin:0!important}
.email-bulk-actions-panel{margin-top:14px;padding:12px;border:1px solid var(--line);border-radius:16px;background:#fbfaf7}
.email-bulk-actions-title{font-weight:900;color:#111;margin-bottom:8px}
.email-bulk-actions-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.email-bulk-actions-row select{max-width:260px;margin:0}
.email-contact-control-icons{margin-left:0}
.email-contact-control-icons .contact-state-icon{width:32px;height:32px}
.email-communications-table .email-no-send-label{margin-left:6px}
@media(max-width:760px){.email-selection-toolbar-wide{align-items:flex-start}.email-bulk-actions-row{display:grid;grid-template-columns:1fr}.email-bulk-actions-row select{max-width:none;width:100%}}

/* =========================================================
   v1.0.128 · Comunicaciones más ágiles y contactos no pulsables
   ---------------------------------------------------------
   - Emails: filtros plegables y listado visible por defecto.
   - Participantes globales: si está de baja/bloqueado, los iconos
     de WhatsApp/teléfono/email se ven desactivados y no son enlaces.
========================================================= */
.email-mass-card{padding-bottom:18px}
.email-mass-head{align-items:flex-start;gap:18px}
.email-mini-counters{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;min-width:220px}
.email-filters-compact{margin:12px 0 16px;border:1px solid var(--line);border-radius:16px;background:#fffdf8;overflow:hidden}
.email-filters-compact summary{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;padding:12px 14px;font-weight:900;color:#111;list-style:none}
.email-filters-compact summary::-webkit-details-marker{display:none}
.email-filters-compact summary em{font-style:normal;font-size:12px;color:var(--muted);font-weight:800;background:#fff;border:1px solid var(--line);border-radius:999px;padding:5px 9px;white-space:nowrap}
.email-filters-compact[open] summary{border-bottom:1px solid var(--line);background:#f9f2e7}
.email-filter-grid-compact{display:grid;grid-template-columns:repeat(5,minmax(130px,1fr));gap:10px;padding:12px}
.email-filter-grid-compact label{margin:0;font-size:12px;font-weight:900;color:#5f5750}
.email-filter-grid-compact input,.email-filter-grid-compact select{min-height:38px;padding:8px 10px;font-size:13px;margin-top:4px}
.email-filter-actions-compact{display:flex;gap:8px;align-items:center;justify-content:flex-end;padding:0 12px 12px}
.email-message-grid{display:grid;grid-template-columns:minmax(0,1fr) 180px;gap:12px;align-items:end}
.email-main-actions{margin-top:10px}
.email-preview-card{margin-top:16px}
.email-selection-toolbar-compact{position:sticky;top:72px;z-index:30;background:#fffdf8;box-shadow:0 10px 22px rgba(0,0,0,.06)}
.email-selection-actions-inline{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.email-bulk-actions-dropdown{position:relative;display:inline-flex}
.email-bulk-actions-dropdown summary{list-style:none;cursor:pointer;white-space:nowrap}
.email-bulk-actions-dropdown summary::-webkit-details-marker{display:none}
.email-bulk-actions-dropdown[open] summary{background:#111;color:#fff;border-color:#111}
.email-bulk-actions-popover{position:absolute;right:0;top:calc(100% + 8px);z-index:60;min-width:320px;display:grid;gap:8px;padding:12px;border:1px solid var(--line);border-radius:16px;background:#fff;box-shadow:0 18px 45px rgba(0,0,0,.18)}
.email-bulk-actions-popover select{width:100%;margin:0}
.email-bulk-actions-popover .hint{margin:2px 0 0;font-size:12px}
.email-send-safety-note{margin-top:10px;padding:9px 12px;border-radius:12px;background:#f8f3e9;border:1px solid var(--line)}
.icon-link.is-disabled,
.contact-icons-disabled .icon-link.is-disabled{opacity:.32!important;filter:grayscale(1);cursor:not-allowed!important;pointer-events:none;text-decoration:none;box-shadow:none!important;background:#f1f1f1!important;color:#777!important;border-color:#ddd!important}
.contact-icons-disabled .icon-link:not(.is-disabled){opacity:.32!important;filter:grayscale(1);pointer-events:none;cursor:not-allowed!important}
.email-disabled-text{color:#8a7d6d;text-decoration:none;opacity:.75;font-weight:700}
tr.contact-row-no-comunicaciones .participantes-contact-icons:after,
tr.contact-row-bloqueado .participantes-contact-icons:after{content:'No contactar';display:inline-flex;align-items:center;height:26px;padding:0 7px;border-radius:999px;background:#111;color:#fff;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.03em}
tr.contact-row-bloqueado .participantes-contact-icons:after{content:'Bloqueado'}
@media(max-width:1100px){.email-filter-grid-compact{grid-template-columns:repeat(3,minmax(130px,1fr))}.email-selection-toolbar-compact{position:static}.email-message-grid{grid-template-columns:1fr}}
@media(max-width:760px){.email-mass-head{display:block}.email-mini-counters{justify-content:flex-start;margin-top:10px}.email-filter-grid-compact{grid-template-columns:1fr}.email-filter-actions-compact{justify-content:stretch}.email-filter-actions-compact .btn{flex:1}.email-selection-actions-inline{justify-content:flex-start}.email-bulk-actions-popover{left:0;right:auto;min-width:280px}.email-selection-toolbar-compact{align-items:flex-start}}

/* =========================================================
   v1.0.129 · Selección masiva clara en emails
========================================================= */
.btn-success{background:#137333!important;color:#fff!important;border-color:#137333!important}
.email-selection-actions-better{gap:7px;align-items:center}
.email-selected-counter{display:inline-flex!important;align-items:center;height:34px;border-radius:999px;background:#f4f1ec;border:1px solid var(--line);padding:0 10px;color:#333!important;font-size:12px!important;font-weight:900!important;white-space:nowrap}
.email-selection-actions-better .btn{white-space:nowrap}
@media(max-width:760px){.email-selection-actions-better{display:grid;width:100%;grid-template-columns:1fr}.email-selection-actions-better .btn,.email-selection-actions-better details{width:100%}.email-selection-actions-better summary.btn{width:100%}.email-selected-counter{justify-content:center;width:100%}}


/* =========================================================
   v1.0.130 · Emails: interfaz más limpia y menos ruido visual
========================================================= */
.email-pro-card{overflow:visible}.email-pro-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:14px}.email-pro-header h2,.email-list-header-clean h2{margin-bottom:4px}.email-pro-counters{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.email-counter-pill{display:grid;place-items:center;min-width:82px;padding:9px 12px;border-radius:16px;border:1px solid var(--line);background:#fff}.email-counter-pill strong{font-size:21px;line-height:1;color:#111}.email-counter-pill small{font-size:11px;font-weight:900;color:#6b6258;text-transform:uppercase;letter-spacing:.03em}.email-counter-pill.is-ok{background:#e8f5ee;border-color:#b9ddc9}.email-counter-pill.is-warning{background:#fff3cd;border-color:#e6c865}.email-counter-pill.is-danger{background:#ffe0e0;border-color:#eba8a8}.email-pro-compose{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:16px;align-items:start}.email-pro-message{min-width:0}.email-message-grid-pro{grid-template-columns:minmax(0,1fr) 110px}.email-pro-actions-panel{position:sticky;top:74px;display:grid;gap:10px;padding:14px;border:1px solid var(--line);border-radius:18px;background:#fffdf8}.email-pro-actions-panel .btn{width:100%;justify-content:center}.email-send-summary-box{border-radius:16px;background:#111;color:#fff;padding:12px;text-align:center}.email-send-summary-box strong{display:block;font-size:30px;line-height:1}.email-send-summary-box span{display:block;margin-top:4px;font-size:12px;font-weight:800;opacity:.8}.email-filters-slim{margin-top:12px;border:1px solid var(--line);border-radius:16px;background:#fbf8f1;overflow:hidden}.email-filters-slim summary{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 14px;cursor:pointer;list-style:none;font-weight:950}.email-filters-slim summary::-webkit-details-marker{display:none}.email-filters-slim summary strong{font-size:12px;border-radius:999px;background:#fff;border:1px solid var(--line);padding:5px 9px;color:#6b6258}.email-filters-slim[open] summary{border-bottom:1px solid var(--line);background:#f8f0e3}.email-filter-grid-slim{display:grid;grid-template-columns:repeat(5,minmax(120px,1fr));gap:9px;padding:12px}.email-filter-grid-slim label{margin:0;font-size:12px;font-weight:900;color:#5f5750}.email-filter-grid-slim input,.email-filter-grid-slim select{min-height:36px;padding:7px 9px;font-size:13px;margin-top:4px}.email-filter-actions-slim{display:flex;justify-content:flex-end;gap:8px;padding:0 12px 12px}.email-list-card{margin-top:16px}.email-list-header-clean{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:10px}.email-list-main-actions{display:flex;align-items:center;justify-content:flex-end;gap:7px;flex-wrap:wrap}.email-list-main-actions .btn{white-space:nowrap}.email-selection-statusbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:10px 0;padding:9px 10px;border:1px solid var(--line);border-radius:14px;background:#fffdf8}.email-selection-statusbar>span:first-child{display:inline-flex;align-items:center;height:30px;padding:0 10px;border-radius:999px;background:#111;color:#fff;font-size:12px;font-weight:950}.email-selection-statusbar>span:nth-child(2){font-size:12px;font-weight:800;color:#6b6258}.email-bulk-actions-clean{margin-left:auto;position:relative}.email-bulk-actions-clean summary{list-style:none;cursor:pointer;border:1px solid var(--line);border-radius:999px;background:#fff;padding:7px 11px;font-weight:900;font-size:12px}.email-bulk-actions-clean summary::-webkit-details-marker{display:none}.email-bulk-actions-clean[open] summary{background:#111;color:#fff;border-color:#111}.email-bulk-actions-clean>div{position:absolute;right:0;top:calc(100% + 8px);z-index:80;display:grid;grid-template-columns:1fr auto;gap:8px;min-width:330px;padding:12px;border:1px solid var(--line);border-radius:16px;background:#fff;box-shadow:0 18px 45px rgba(0,0,0,.16)}.email-bulk-actions-clean select{margin:0}.email-legend-clean{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:8px 0 10px;color:#5f5750;font-size:12px;font-weight:850}.email-legend-clean span{display:inline-flex;align-items:center;gap:6px}.email-legend-clean i{width:16px;height:16px;border-radius:5px;border:1px solid var(--line)}.email-legend-clean .legend-ok{background:#e8f5ee;border-color:#b9ddc9}.email-legend-clean .legend-warning{background:#fff3cd;border-color:#e6c865}.email-legend-clean .legend-danger{background:#ffe0e0;border-color:#eba8a8}.email-clean-wrap{border:1px solid var(--line);border-radius:18px;background:#fff;overflow:auto}.email-clean-table{width:100%;border-collapse:separate;border-spacing:0;min-width:880px}.email-clean-table th{position:sticky;top:0;z-index:5;background:#f8f3e9;font-size:12px;text-transform:uppercase;letter-spacing:.03em}.email-clean-table th,.email-clean-table td{padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:middle}.email-clean-table tr:last-child td{border-bottom:0}.email-clean-table tr.contact-row-no-comunicaciones>td{background:#fff3cd!important}.email-clean-table tr.contact-row-bloqueado>td{background:#ffe0e0!important}.email-clean-table tr.contact-row-no-comunicaciones>td:first-child{border-left:7px solid #f59f00!important}.email-clean-table tr.contact-row-bloqueado>td:first-child{border-left:7px solid #d92d20!important}.email-check-cell{width:62px;text-align:center}.email-check-cell input{width:19px;height:19px}.email-lock-dot{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;background:#6b7280;color:#fff;font-weight:950}.email-contact-cell-clean strong{display:block;color:#111;font-size:14px}.email-contact-cell-clean span,.email-contact-cell-clean small{display:block;color:#5f5750;font-size:12px;font-weight:750;line-height:1.35}.email-contact-cell-clean small{color:#8a7d6d}.email-state-cell-clean .badge{margin-right:6px}.email-state-cell-clean strong{display:inline-flex;margin-top:4px;border-radius:999px;background:#111;color:#fff;font-size:10px;padding:4px 7px;letter-spacing:.04em}.email-participation-cell-clean strong{display:block;max-width:280px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#111;font-size:13px}.email-participation-cell-clean span{display:block;color:#6b6258;font-size:12px;font-weight:800}.email-control-cell-clean{width:96px}.email-control-cell-clean .contact-control-icons{justify-content:flex-start}.email-control-cell-clean .contact-state-icon{width:32px;height:32px}.email-create-selected-disabled-note{font-size:12px;color:#6b6258}@media(max-width:1100px){.email-pro-compose{grid-template-columns:1fr}.email-pro-actions-panel{position:static}.email-filter-grid-slim{grid-template-columns:repeat(3,minmax(120px,1fr))}.email-list-header-clean{display:block}.email-list-main-actions{justify-content:flex-start;margin-top:10px}.email-bulk-actions-clean{margin-left:0}}@media(max-width:760px){.email-pro-header{display:block}.email-pro-counters{justify-content:flex-start;margin-top:10px}.email-message-grid-pro{grid-template-columns:1fr}.email-filter-grid-slim{grid-template-columns:1fr}.email-filter-actions-slim{justify-content:stretch}.email-filter-actions-slim .btn{flex:1}.email-list-main-actions{display:grid;grid-template-columns:1fr;width:100%}.email-list-main-actions .btn{width:100%}.email-selection-statusbar{align-items:flex-start}.email-bulk-actions-clean{width:100%}.email-bulk-actions-clean summary{text-align:center}.email-bulk-actions-clean>div{position:static;min-width:0;margin-top:8px;grid-template-columns:1fr}.email-clean-table{min-width:760px}}

/* =========================================================
   v1.0.131 · Emails: filtros dinámicos y selección de visibles
========================================================= */
.email-list-main-actions-simple{gap:8px;align-items:center}
.email-list-main-actions-simple .btn-success{font-weight:950;box-shadow:0 8px 20px rgba(19,115,51,.16)}
.email-live-toolbar{display:grid;grid-template-columns:minmax(240px,1.8fr) minmax(150px,1fr) minmax(150px,.85fr) minmax(150px,.85fr) auto;gap:8px;align-items:center;margin:10px 0 8px;padding:10px;border:1px solid var(--line);border-radius:16px;background:#fbf8f1}
.email-live-toolbar select,.email-live-toolbar input{min-height:38px;margin:0;font-size:13px;padding:8px 10px;background:#fff}
.email-live-searchbox{display:flex;align-items:center;gap:8px;border:1px solid var(--line);background:#fff;border-radius:12px;padding:0 10px;min-height:38px}
.email-live-searchbox span{opacity:.65;font-size:14px}.email-live-searchbox input{border:0;box-shadow:none;padding-left:0;width:100%;min-height:34px}.email-live-searchbox input:focus{outline:0;box-shadow:none}
#email_visible_counter{background:#111!important;color:#fff!important}#email_selected_counter{display:inline-flex;align-items:center;height:30px;padding:0 10px;border-radius:999px;background:#e8f5ee!important;border:1px solid #b9ddc9;color:#137333!important;font-size:12px!important;font-weight:950!important}
#email_select_visible_master{width:18px;height:18px}.email-clean-table tbody tr{transition:background .15s ease,opacity .15s ease}.email-clean-table tbody tr:hover td{filter:brightness(.985)}
#email_create_visible_btn:disabled,#email_create_selected_btn:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.4)}
@media(max-width:1100px){.email-live-toolbar{grid-template-columns:1fr 1fr}.email-live-searchbox{grid-column:1/-1}}
@media(max-width:760px){.email-live-toolbar{grid-template-columns:1fr}.email-live-toolbar .btn{width:100%}.email-selection-statusbar{gap:7px}.email-selection-statusbar>span{width:100%;justify-content:center}.email-list-main-actions-simple{grid-template-columns:1fr}}

/* Archivo: /porra/assets/css/style.css · Parche versión 1.0.132 · Envío masivo profesional */
.email-workbench-v132{padding:0;overflow:hidden;border-radius:24px}
.email-workbench-form-v132{margin:0}
.email-workbench-top-v132{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:22px 24px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#fff,#fffaf2)}
.email-workbench-top-v132 h2{margin:.1rem 0 .25rem;font-size:28px;line-height:1.1}
.email-workbench-top-v132 .hint{margin:0;max-width:760px}
.email-workbench-counters-v132{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;min-width:260px}
.email-workbench-counters-v132 span{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:8px 11px;font-weight:800;font-size:13px;white-space:nowrap;border:1px solid transparent}
.email-workbench-counters-v132 strong{font-size:18px;line-height:1}
.email-workbench-counters-v132 .pill-ok{background:#e9f7ef;color:#12612d;border-color:#ccebd8}
.email-workbench-counters-v132 .pill-warning{background:#fff6db;color:#765300;border-color:#f0d98e}
.email-workbench-counters-v132 .pill-danger{background:#fdebea;color:#a12018;border-color:#f3c8c3}
.email-commandbar-v132{display:flex;align-items:center;gap:9px;flex-wrap:wrap;padding:14px 24px;border-bottom:1px solid var(--line);background:#fff}
.email-commandbar-v132 .btn{margin:0;padding:10px 15px;font-size:13px;min-height:40px}
.email-commandbar-v132 .btn-success{background:#137333;color:#fff}
.email-selected-pill-v132{margin-left:auto;background:#111;color:#fff;border-radius:999px;padding:8px 12px;font-weight:900;font-size:13px;white-space:nowrap}
.email-bulk-actions-v132{position:relative}
.email-bulk-actions-v132 summary{list-style:none;cursor:pointer;border:1px solid var(--line);border-radius:999px;padding:9px 13px;font-weight:900;font-size:13px;background:#fff;white-space:nowrap}
.email-bulk-actions-v132 summary::-webkit-details-marker{display:none}
.email-bulk-actions-v132[open] summary{background:#111;color:#fff;border-color:#111}
.email-bulk-actions-v132>div{position:absolute;right:0;z-index:20;display:flex;gap:8px;align-items:end;min-width:360px;margin-top:8px;padding:12px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow)}
.email-bulk-actions-v132 select{margin:0;padding:10px 12px;border-radius:12px}
.email-filterbar-v132{display:grid;grid-template-columns:minmax(260px,1.7fr) minmax(140px,.7fr) minmax(150px,.7fr) minmax(150px,.7fr) auto;gap:10px;align-items:center;padding:14px 24px;background:#fbf8f1;border-bottom:1px solid var(--line)}
.email-search-v132{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #ded3c8;border-radius:14px;padding:0 12px;height:44px;min-width:0}
.email-search-v132 input{border:0;padding:0;margin:0;height:42px;background:transparent;outline:0;min-width:0}
.email-filterbar-v132 select{height:44px;padding:0 12px;margin:0;border-radius:14px;background:#fff;font-size:14px}
.email-filterbar-v132 .btn{margin:0;height:44px;padding:0 14px;white-space:nowrap}
.email-statusline-v132{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 24px;background:#111;color:#fff;font-size:13px;font-weight:800}
.email-statusline-v132 span:last-child{font-weight:600;color:#e9e2d7;text-align:right}
.email-table-wrap-v132{margin:0;overflow:auto;max-height:calc(100vh - 260px);background:#fff}
.email-table-v132{min-width:1120px;border-collapse:separate;border-spacing:0;width:100%}
.email-table-v132 th{position:sticky;top:0;z-index:5;background:#fffaf2;border-bottom:1px solid #ded3c8;padding:10px 10px;font-size:12px;letter-spacing:.06em;color:#62544a;white-space:nowrap;text-align:left}
.email-table-v132 td{padding:10px;border-bottom:1px solid #eee4d9;vertical-align:middle;background:#fff}
.email-table-v132 tbody tr:hover td{background:#fffdf8}
.email-select-col-v132,.email-check-cell-v132{width:44px;text-align:center!important}
.email-check-cell-v132 input{width:18px;height:18px;margin:0;accent-color:#111}
.email-contact-v132{min-width:260px;max-width:330px}
.email-contact-v132 strong{display:block;font-size:15px;line-height:1.15;margin-bottom:3px}
.email-contact-v132 a{display:block;color:#0b57d0;text-decoration:none;font-size:13px;word-break:break-all}
.email-contact-v132 small,.email-contact-v132 em{display:block;color:var(--muted);font-size:12px;font-style:normal;margin-top:2px}
.email-state-v132{min-width:128px}
.email-state-v132 strong{display:block;margin-top:5px;color:#a12018;font-size:11px;letter-spacing:.08em}
.email-votes-v132{min-width:92px;white-space:nowrap}
.email-votes-v132 strong{display:block;font-size:20px;line-height:1;color:#111}
.email-votes-v132 span{display:block;font-size:11px;color:var(--muted);font-weight:800}
.email-total-points-v132{width:76px;text-align:center!important}
.email-total-points-v132 strong{display:inline-grid;place-items:center;min-width:42px;height:34px;border-radius:12px;background:#111;color:#fff;font-size:18px}
.email-points-col-v132,.email-points-cell-v132{width:58px;text-align:center!important}
.email-points-cell-v132 strong{display:block;font-size:16px;line-height:1.05}
.email-points-cell-v132 small{display:block;font-size:9px;color:#9b6a00;text-transform:uppercase;font-weight:900;margin-top:2px}
.email-actions-v132{width:92px;text-align:right!important;white-space:nowrap}
.email-actions-v132 .contact-control-icons{justify-content:flex-end}
.email-table-v132 tr.contact-row-no-comunicaciones td{background:#fff3cd!important}
.email-table-v132 tr.contact-row-no-comunicaciones:hover td{background:#ffe8a3!important}
.email-table-v132 tr.contact-row-bloqueado td{background:#fce8e6!important}
.email-table-v132 tr.contact-row-bloqueado:hover td{background:#fad1cc!important}
.email-table-v132 tr.contact-row-no-comunicaciones .email-contact-v132 a,
.email-table-v132 tr.contact-row-bloqueado .email-contact-v132 a{color:#5f6368;pointer-events:none;text-decoration:none;opacity:.65}
.email-lock-dot{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:999px;background:#eee;color:#777;font-weight:950}
.email-message-grid-pro{grid-template-columns:minmax(0,1fr) 110px}.email-pro-compose{align-items:start}
@media(max-width:1100px){.email-workbench-top-v132{flex-direction:column}.email-workbench-counters-v132{justify-content:flex-start;min-width:0}.email-filterbar-v132{grid-template-columns:1fr 1fr}.email-search-v132{grid-column:1/-1}.email-selected-pill-v132{margin-left:0}.email-bulk-actions-v132>div{right:auto;left:0}}
@media(max-width:760px){.email-workbench-top-v132,.email-commandbar-v132,.email-filterbar-v132,.email-statusline-v132{padding-left:14px;padding-right:14px}.email-filterbar-v132{grid-template-columns:1fr}.email-commandbar-v132 .btn{width:100%}.email-selected-pill-v132{width:100%;text-align:center}.email-statusline-v132{display:block}.email-statusline-v132 span{display:block;margin:2px 0;text-align:left!important}.email-bulk-actions-v132{width:100%}.email-bulk-actions-v132 summary{width:100%;text-align:center}.email-bulk-actions-v132>div{position:static;min-width:0;display:grid}.email-table-wrap-v132{max-height:none}.email-table-v132{min-width:920px}}

/* =========================================================
   v1.0.133 · Emails: mesa de trabajo profesional
   ---------------------------------------------------------
   Rediseño visual de admin/emails.php: redacción clara, filtros
   rápidos compactos, selección usable y tabla con datos reales.
========================================================= */
.email-compose-card-v133,
.email-workbench-v133{border:1px solid #e8ddd1;border-radius:26px;background:#fff;box-shadow:0 18px 45px rgba(60,42,25,.08);overflow:hidden}
.email-compose-head-v133,
.email-workbench-head-v133{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:22px 26px;background:linear-gradient(135deg,#fffaf1 0%,#ffffff 56%,#f7fbf8 100%);border-bottom:1px solid #ecdfd3}
.email-title-line-v133{display:flex;align-items:flex-start;gap:14px}
.email-step-badge-v133{display:inline-grid;place-items:center;flex:0 0 auto;width:38px;height:38px;border-radius:14px;background:#111;color:#fff;font-weight:950;font-size:18px;box-shadow:0 10px 22px rgba(0,0,0,.16)}
.email-compose-head-v133 h2,
.email-workbench-head-v133 h2{margin:.05rem 0 .22rem;font-size:28px;line-height:1.08;letter-spacing:-.03em;color:#111}
.email-compose-head-v133 .hint,
.email-workbench-head-v133 .hint{margin:0;max-width:780px;color:#6f6257;font-weight:650}
.email-compose-kpis-v133,
.email-kpi-row-v133{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end;min-width:285px}
.email-compose-kpis-v133 span,
.email-kpi-v133{display:inline-flex;flex-direction:column;align-items:flex-start;justify-content:center;min-width:88px;border-radius:18px;padding:9px 12px;border:1px solid transparent;background:#fff;box-shadow:0 8px 18px rgba(60,42,25,.05)}
.email-compose-kpis-v133 strong,
.email-kpi-v133 strong{font-size:22px;line-height:1;color:#111}
.email-compose-kpis-v133 small,
.email-kpi-v133 small{font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.05em;color:#6d6258;margin-top:3px}
.email-compose-kpis-v133 .is-ok,.email-kpi-v133.is-ok{background:#eaf7ef;border-color:#cbead7}
.email-compose-kpis-v133 .is-warning,.email-kpi-v133.is-warning{background:#fff4cf;border-color:#f1da8b}
.email-compose-kpis-v133 .is-danger,.email-kpi-v133.is-danger{background:#fde9e7;border-color:#f3c4bf}
.email-compose-form-v133{display:block;padding:20px 26px 22px;margin:0;background:#fff}
.email-compose-grid-v133{display:grid;grid-template-columns:minmax(0,1fr) 120px;gap:12px;align-items:end;margin-bottom:12px}
.email-compose-form-v133 label{font-weight:900;color:#1f2937}
.email-compose-form-v133 input,
.email-compose-form-v133 textarea,
.email-compose-form-v133 select{border:1px solid #d9cfc4;background:#fff;border-radius:14px;box-shadow:none;min-height:44px;font-size:15px}
.email-compose-form-v133 textarea{min-height:150px;line-height:1.45;resize:vertical}
.email-body-field-v133{display:block}.email-body-field-v133 textarea{margin-top:6px}
.email-compose-footer-v133{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;flex-wrap:wrap}
.email-vars-v133 summary{display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:1px solid #e2d7cb;background:#fbf8f3;border-radius:999px;padding:8px 12px;font-size:13px;font-weight:900;list-style:none}
.email-vars-v133 summary::-webkit-details-marker{display:none}.email-vars-v133[open] summary{background:#111;color:#fff;border-color:#111}
.email-vars-v133 div{margin-top:8px;padding:10px 12px;border:1px solid #e2d7cb;border-radius:14px;background:#fbf8f3;color:#5f5146;font-size:13px;font-weight:750}
.email-server-filters-v133{margin-top:14px;border:1px dashed #ddcfc1;background:#fffdf9;border-radius:18px;padding:0;overflow:hidden}
.email-server-filters-v133 summary{display:flex;justify-content:space-between;gap:12px;padding:12px 14px;cursor:pointer;font-weight:950;list-style:none}
.email-server-filters-v133 summary::-webkit-details-marker{display:none}.email-server-filters-v133 summary strong{font-size:12px;color:#6d6258}
.email-server-filters-v133 .email-filter-grid-slim{padding:12px 14px;border-top:1px solid #eee3d7}.email-server-filters-v133 .email-filter-actions-slim{padding:0 14px 14px}
.email-workbench-v133{padding:0;margin-top:20px}
.email-workbench-form-v133{margin:0;padding:0}.email-action-dock-v133{position:sticky;top:0;z-index:15;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 26px;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-bottom:1px solid #e8ddd1;box-shadow:0 8px 22px rgba(60,42,25,.05)}
.email-main-actions-v133,.email-selection-actions-v133{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.email-main-cta-v133{background:#111!important;border-color:#111!important;color:#fff!important;font-weight:950;box-shadow:0 12px 24px rgba(0,0,0,.18)}
.email-action-dock-v133 .btn{margin:0;min-height:40px;border-radius:999px;padding:9px 14px;font-size:13px;font-weight:900}.email-selected-pill-v133{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 13px;border-radius:999px;background:#f0f7f2;border:1px solid #cbead7;color:#137333;font-weight:950;font-size:13px;white-space:nowrap}
.email-bulk-actions-v133{position:relative}.email-bulk-actions-v133 summary{list-style:none;cursor:pointer;border:1px solid #d9cfc4;border-radius:999px;padding:9px 14px;font-weight:950;font-size:13px;background:#fff;white-space:nowrap}.email-bulk-actions-v133 summary::-webkit-details-marker{display:none}.email-bulk-actions-v133[open] summary{background:#111;color:#fff;border-color:#111}
.email-bulk-actions-v133>div{position:absolute;right:0;z-index:30;display:flex;gap:8px;align-items:center;min-width:370px;margin-top:8px;padding:12px;background:#fff;border:1px solid #e0d5c9;border-radius:18px;box-shadow:0 20px 45px rgba(0,0,0,.16)}.email-bulk-actions-v133 select{margin:0;min-height:40px;border-radius:12px}
.email-smartbar-v133{display:grid;grid-template-columns:minmax(300px,1.8fr) minmax(160px,.8fr) minmax(150px,.7fr) minmax(150px,.7fr) auto;gap:10px;align-items:center;padding:14px 26px;background:#fbf8f2;border-bottom:1px solid #e8ddd1}.email-smartbar-v133 select,.email-smartbar-v133 .btn{height:44px;margin:0;border-radius:14px}.email-smartbar-v133 select{background:#fff;border:1px solid #d9cfc4;font-size:14px;font-weight:700;color:#2f2923;padding:0 12px}
.email-search-v133{display:flex;align-items:center;gap:10px;min-width:0;height:44px;padding:0 13px;background:#fff;border:1px solid #d9cfc4;border-radius:15px}.email-search-v133 span{opacity:.7}.email-search-v133 input{width:100%;height:42px;border:0!important;background:transparent!important;box-shadow:none!important;padding:0!important;margin:0!important;outline:0;font-size:14px}
.email-statusline-v133{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 26px;background:#191817;color:#fff;font-size:13px;font-weight:800}.email-statusline-v133 span:first-child{display:inline-flex;align-items:center;border-radius:999px;background:#fff;color:#111;padding:5px 10px;font-weight:950}.email-statusline-v133 span:last-child{color:#e6ddd4;font-weight:650;text-align:right}
.email-table-wrap-v133{margin:0;max-height:calc(100vh - 255px);overflow:auto;background:#fff}.email-table-v133{width:100%;min-width:1180px;border-collapse:separate;border-spacing:0}.email-table-v133 th{position:sticky;top:0;z-index:6;background:#fffaf2;color:#5f5146;border-bottom:1px solid #ddd0c3;font-size:11px;text-transform:uppercase;letter-spacing:.075em;font-weight:950;padding:10px 11px;text-align:left;white-space:nowrap}.email-table-v133 td{padding:12px 11px;border-bottom:1px solid #eee4d8;background:#fff;vertical-align:middle}.email-table-v133 tbody tr{cursor:pointer;transition:background .14s ease,box-shadow .14s ease}.email-table-v133 tbody tr:hover td{background:#fffdf7}.email-table-v133 tbody tr.is-selected-for-send td{background:#ecf8f0!important;box-shadow:inset 0 1px 0 #cbead7,inset 0 -1px 0 #cbead7}.email-table-v133 tbody tr.is-selected-for-send td:first-child{box-shadow:inset 5px 0 0 #137333,inset 0 1px 0 #cbead7,inset 0 -1px 0 #cbead7}
.email-select-col-v133,.email-check-cell-v133{width:48px;text-align:center!important}.email-check-cell-v133 input{width:20px;height:20px;margin:0;accent-color:#111;cursor:pointer}.email-lock-dot-v133{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:999px;background:#e9e1d9;color:#75675b;font-weight:950}.email-center-v133{text-align:center!important}.email-person-v133{min-width:230px;max-width:290px}.email-person-v133 strong{display:block;color:#111;font-size:15px;line-height:1.15;margin-bottom:4px}.email-person-v133 span,.email-person-v133 small{display:block;color:#70645a;font-size:12px;line-height:1.25;font-weight:700}.email-person-v133 small{margin-top:3px;color:#9a6b13}.email-contact-v133{min-width:255px;max-width:330px}.email-contact-v133 a{display:block;color:#0b57d0;text-decoration:none;font-weight:850;word-break:break-all;font-size:13px}.email-contact-v133 span{display:block;color:#5f6368;font-weight:750;font-size:12px;margin-top:4px}.email-state-v133{min-width:120px}.email-state-v133 .badge{font-weight:950}.email-state-v133 strong{display:inline-flex;margin-top:5px;border-radius:999px;background:#111;color:#fff;padding:4px 7px;font-size:10px;letter-spacing:.08em}.email-votes-v133{width:105px}.email-votes-v133 strong{display:block;font-size:22px;line-height:1;color:#111}.email-votes-v133 span{display:block;color:#6f6257;font-size:11px;font-weight:850;white-space:nowrap}.email-total-points-v133{width:82px;text-align:center!important}.email-total-points-v133 strong{display:inline-grid;place-items:center;min-width:46px;height:36px;border-radius:14px;background:#111;color:#fff;font-size:19px;font-weight:950}.email-points-col-v133,.email-points-cell-v133{width:62px;text-align:center!important}.email-points-cell-v133 strong{display:block;font-size:17px;color:#111;line-height:1}.email-points-cell-v133 small{display:block;margin-top:3px;font-size:9px;font-weight:950;text-transform:uppercase;color:#956200}.email-actions-v133{width:96px;text-align:center!important}.email-actions-v133 .contact-control-icons{justify-content:center;margin:0}.email-actions-v133 .contact-state-icon{width:32px;height:32px;box-shadow:none}
.email-table-v133 tr.contact-row-no-comunicaciones td{background:#fff2c2!important}.email-table-v133 tr.contact-row-no-comunicaciones:hover td{background:#ffe8a1!important}.email-table-v133 tr.contact-row-no-comunicaciones td:first-child{box-shadow:inset 6px 0 0 #f59f00}.email-table-v133 tr.contact-row-bloqueado td{background:#fde1df!important}.email-table-v133 tr.contact-row-bloqueado:hover td{background:#facac5!important}.email-table-v133 tr.contact-row-bloqueado td:first-child{box-shadow:inset 6px 0 0 #d92d20}.email-table-v133 tr.contact-row-no-comunicaciones .email-contact-v133 a,.email-table-v133 tr.contact-row-bloqueado .email-contact-v133 a{pointer-events:none;text-decoration:none;color:#5f6368;opacity:.68}
.email-table-v133 tr.contact-row-no-comunicaciones,.email-table-v133 tr.contact-row-bloqueado{cursor:default}.email-table-v133 tr.contact-row-no-comunicaciones .email-person-v133 strong:after{content:' · No contactar';color:#9a6b00;font-size:11px;font-weight:950}.email-table-v133 tr.contact-row-bloqueado .email-person-v133 strong:after{content:' · Bloqueado';color:#a12018;font-size:11px;font-weight:950}
@media(max-width:1180px){.email-action-dock-v133{align-items:flex-start;flex-direction:column}.email-smartbar-v133{grid-template-columns:1fr 1fr}.email-search-v133{grid-column:1/-1}.email-compose-head-v133,.email-workbench-head-v133{flex-direction:column}.email-compose-kpis-v133,.email-kpi-row-v133{justify-content:flex-start;min-width:0}}
@media(max-width:760px){.email-compose-head-v133,.email-workbench-head-v133,.email-compose-form-v133,.email-action-dock-v133,.email-smartbar-v133,.email-statusline-v133{padding-left:14px;padding-right:14px}.email-compose-grid-v133,.email-smartbar-v133{grid-template-columns:1fr}.email-main-actions-v133,.email-selection-actions-v133{display:grid;grid-template-columns:1fr;width:100%}.email-action-dock-v133 .btn{width:100%}.email-selected-pill-v133{width:100%}.email-statusline-v133{display:block}.email-statusline-v133 span{display:flex!important;justify-content:center;margin:3px 0;text-align:center!important}.email-bulk-actions-v133>div{position:static;min-width:0;display:grid;margin-top:8px}.email-bulk-actions-v133{width:100%}.email-bulk-actions-v133 summary{text-align:center}.email-table-wrap-v133{max-height:none}.email-table-v133{min-width:980px}}

/* ==========================================================
   Porra Aínsa Sound · Emails admin v1.0.134
   Grid compacto, filtros en línea y ordenación visual.
   ========================================================== */
.email-compose-card-v133{padding:20px 24px!important;border-radius:22px;background:linear-gradient(180deg,#fff,#fffaf3);box-shadow:0 10px 34px rgba(35,25,15,.06)}
.email-compose-head-v133{margin-bottom:14px!important}.email-compose-head-v133 h2{font-size:24px;margin:0}.email-compose-head-v133 .hint{margin-top:3px;max-width:760px}
.email-compose-kpis-v133 span,.email-kpi-v133{border-radius:16px!important;box-shadow:0 2px 10px rgba(0,0,0,.035)}
.email-compose-grid-v133{grid-template-columns:minmax(0,1fr) 104px!important;gap:12px!important}.email-compose-form-v133 input,.email-compose-form-v133 textarea{border-radius:14px!important}.email-compose-form-v133 textarea{min-height:118px!important}
.email-vars-v133 summary{padding:7px 11px!important;font-size:12px!important}.email-compose-footer-v133 .btn{min-height:36px!important;padding:7px 12px!important}
.email-server-filters-v133{margin-top:10px!important;border-radius:16px!important}.email-server-filters-v133 summary{padding:9px 12px!important}.email-server-filters-v133 .email-filter-grid-slim{grid-template-columns:repeat(9,minmax(84px,1fr))!important;gap:7px!important;padding:10px 12px!important}.email-server-filters-v133 .email-filter-grid-slim label{font-size:10px!important;letter-spacing:.03em;text-transform:uppercase}.email-server-filters-v133 .email-filter-grid-slim input,.email-server-filters-v133 .email-filter-grid-slim select{min-height:32px!important;font-size:12px!important;border-radius:10px!important;padding:5px 7px!important}
.email-workbench-v133{border-radius:22px!important;overflow:hidden;background:#fff;box-shadow:0 12px 38px rgba(35,25,15,.07)}
.email-workbench-head-v133{padding:18px 24px 10px!important;border-bottom:0!important}.email-title-line-v133 h2{font-size:24px;margin:0}.email-title-line-v133 .hint{margin-top:3px}.email-step-badge-v133{width:34px!important;height:34px!important;font-size:16px!important}
.email-action-dock-v133{top:0!important;padding:10px 20px!important;background:rgba(255,255,255,.97)!important;gap:10px!important}.email-main-actions-v133,.email-selection-actions-v133{gap:6px!important}.email-action-dock-v133 .btn{min-height:34px!important;padding:7px 12px!important;font-size:12px!important;border-radius:12px!important}.email-main-cta-v133{box-shadow:none!important}.email-btn-icon-v134{display:inline-flex;margin-right:5px}.email-selected-pill-v133{min-height:32px!important;padding:0 10px!important;font-size:12px!important;border-radius:12px!important}.email-bulk-actions-v133 summary{height:34px;min-width:38px;padding:7px 10px!important;text-align:center;font-size:16px!important}.email-bulk-actions-v133>div{right:0;min-width:330px!important;border-radius:14px!important}
.email-smartbar-v133{display:grid!important;grid-template-columns:minmax(260px,2.3fr) minmax(138px,.8fr) minmax(122px,.7fr) minmax(122px,.7fr) 42px!important;align-items:center!important;gap:8px!important;padding:10px 20px!important;background:#f6efe6!important}.email-smartbar-v133 select,.email-smartbar-v133 .btn,.email-search-v133{height:38px!important;min-height:38px!important;border-radius:12px!important}.email-smartbar-v133 select{font-size:12px!important;font-weight:850!important;padding:0 9px!important}.email-search-v133{padding:0 10px!important}.email-search-v133 input{height:36px!important;font-size:13px!important}.email-smartbar-v133 .btn{width:42px!important;padding:0!important;display:inline-grid;place-items:center;font-size:15px!important}.email-statusline-v133{padding:7px 20px!important;font-size:12px!important}.email-statusline-v133 span:first-child{padding:4px 8px!important}.email-statusline-v133 span:last-child{font-size:11px!important}
.email-table-wrap-v133{max-height:calc(100vh - 225px)!important;border-top:1px solid #e2d7cb}.email-table-v133{min-width:1040px!important;border-collapse:separate!important;border-spacing:0!important}.email-table-v133 th{padding:7px 8px!important;background:#f9f3ea!important;color:#4d433a!important;border-bottom:1px solid #d9ccbf!important}.email-table-v133 td{padding:8px 8px!important}.email-table-v133 tbody tr:hover td{background:#fff8ed!important}.email-sort-btn-v134{appearance:none;border:0;background:transparent;color:inherit;width:100%;display:inline-flex;align-items:center;gap:5px;justify-content:flex-start;padding:0;margin:0;font:inherit;font-size:11px!important;font-weight:950!important;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;white-space:nowrap}.email-sort-btn-v134.is-center{justify-content:center}.email-sort-btn-v134 span{font-size:13px;line-height:1}.email-sort-btn-v134 em{font-style:normal}.email-sort-btn-v134 i{font-style:normal;margin-left:auto;opacity:.45;font-size:12px}.email-sort-btn-v134.is-center i{margin-left:3px}.email-sort-btn-v134:hover,.email-sort-btn-v134.is-active{color:#111}.email-sort-btn-v134.is-active i{opacity:1;color:#137333}.email-select-col-v133,.email-check-cell-v133{width:42px!important}.email-check-cell-v133 input{width:18px!important;height:18px!important}.email-lock-dot-v133{width:22px!important;height:22px!important;font-size:12px!important}.email-person-v133{min-width:190px!important;max-width:260px!important}.email-person-v133 strong{font-size:14px!important;line-height:1.12!important;margin-bottom:3px!important}.email-person-v133 span,.email-person-v133 small{font-size:11px!important;line-height:1.18!important}.email-person-v133 small{display:inline-flex!important;margin-top:3px!important;border-radius:999px;background:#fff1d6;color:#8a5600;padding:2px 6px}.email-contact-v133{min-width:220px!important;max-width:310px!important}.email-contact-v133 a{font-size:12px!important;line-height:1.2!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:290px}.email-contact-v133 span{font-size:11px!important;margin-top:3px!important}.email-state-v133{min-width:64px!important;width:70px!important;text-align:center!important}.email-state-chip-v134{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:999px;font-size:16px;font-weight:950;border:1px solid transparent}.email-state-chip-v134.is-ok{background:#e8f5ee;border-color:#b9ddc9}.email-state-chip-v134.is-warning{background:#fff3cd;border-color:#e3bd45}.email-state-chip-v134.is-danger{background:#ffe0e0;border-color:#e7a09b}.email-votes-v133{width:74px!important}.email-votes-v133 strong{font-size:18px!important}.email-votes-v133 span{font-size:10px!important;letter-spacing:.01em;white-space:nowrap}.email-total-points-v133{width:66px!important}.email-total-points-v133 strong{min-width:36px!important;height:30px!important;border-radius:10px!important;font-size:16px!important}.email-points-col-v133,.email-points-cell-v133{width:52px!important}.email-points-cell-v133 strong{font-size:15px!important}.email-points-cell-v133 small{font-size:11px!important;margin-top:0!important;color:#b26b00}.email-actions-v133{width:78px!important}.email-actions-v133 .contact-state-icon{width:28px!important;height:28px!important;font-size:14px!important}.email-actions-v133 .contact-control-icons{gap:4px!important}.email-table-v133 tr.contact-row-no-comunicaciones td{background:#fff4cf!important}.email-table-v133 tr.contact-row-bloqueado td{background:#ffe5e2!important}.email-table-v133 tr.contact-row-no-comunicaciones .email-state-chip-v134,.email-table-v133 tr.contact-row-bloqueado .email-state-chip-v134{box-shadow:0 0 0 3px rgba(255,255,255,.55)}.email-table-v133 tr.contact-row-no-comunicaciones .email-person-v133 strong:after,.email-table-v133 tr.contact-row-bloqueado .email-person-v133 strong:after{content:''!important}.email-table-v133 tbody tr.is-selected-for-send td{background:#eaf7ee!important}.email-table-v133 tbody tr.is-selected-for-send td:first-child{box-shadow:inset 4px 0 0 #137333!important}
@media(max-width:1260px){.email-server-filters-v133 .email-filter-grid-slim{grid-template-columns:repeat(3,minmax(120px,1fr))!important}.email-smartbar-v133{grid-template-columns:minmax(240px,1fr) 1fr 1fr 1fr 42px!important}.email-table-v133{min-width:1000px!important}}
@media(max-width:900px){.email-smartbar-v133{grid-template-columns:1fr 1fr!important}.email-search-v133{grid-column:1/-1}.email-smartbar-v133 .btn{width:100%!important}.email-action-dock-v133{position:static!important;align-items:stretch!important}.email-main-actions-v133,.email-selection-actions-v133{display:flex!important}.email-server-filters-v133 .email-filter-grid-slim{grid-template-columns:1fr!important}}
@media(max-width:650px){.email-smartbar-v133{grid-template-columns:1fr!important}.email-main-actions-v133,.email-selection-actions-v133{display:grid!important;grid-template-columns:1fr 1fr}.email-main-actions-v133 .email-main-cta-v133{grid-column:1/-1}.email-selected-pill-v133{justify-content:center}.email-table-v133{min-width:940px!important}}

/* v1.0.138 · WhatsApp directo en el grid de emails */
.email-contact-phone-v138{display:flex;align-items:center;gap:8px;margin-top:3px;min-width:0}
.email-contact-phone-v138 span{margin-top:0!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.email-contact-phone-v138 .email-whatsapp-v138{display:inline-grid!important;place-items:center!important;flex:0 0 auto;width:25px!important;height:25px!important;min-width:25px!important;border-radius:999px!important;font-size:13px!important;line-height:1!important;text-decoration:none!important;box-shadow:none!important;word-break:normal!important;overflow:visible!important;text-overflow:clip!important;max-width:none!important;color:#fff!important;background:#128c3c!important}
.email-contact-phone-v138 .email-whatsapp-v138:hover{transform:translateY(-1px);box-shadow:0 4px 10px rgba(0,0,0,.14)!important}
.email-table-v133 tr.contact-row-no-comunicaciones .email-contact-phone-v138 .email-whatsapp-v138,
.email-table-v133 tr.contact-row-bloqueado .email-contact-phone-v138 .email-whatsapp-v138{opacity:.35!important;filter:grayscale(1);pointer-events:none!important;cursor:not-allowed!important;box-shadow:none!important;transform:none!important}
