@charset "UTF-8";

/* =========================================================
   THEME / VARIABLES
========================================================= */
:root{
  --bg:#f6f7f9;
  --card:#ffffff;
  --border:#e7e7ea;
  --text:#1c1f23;
  --muted:#6b7280;

  --club-green:#0f6b4f;
  --club-green-2:#0b5a42;

  /* semantic */
  --win:#0a7a2f;
  --win-bg:#e6f6ec;
  --lose:#b42318;
  --lose-bg:#fde8e8;

  --radius-md:14px;
  --shadow-soft:0 6px 18px rgba(0,0,0,.06);

  --app-max:520px;

  /* Clasificación (home + página) */
  --clas-col-pos: 32px;
  --clas-col-pts: 44px;
  --clas-col-num: 32px; /* J / G / P */
}

/* =========================================================
   BASE
========================================================= */
html,body{height:100%}
body{
  background:var(--bg);
  color:var(--text);
  font-family:Tahoma,Arial,sans-serif;
}
.nowrap{white-space:nowrap}

.card-soft{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
}

.brand-title{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.brand-user{
  font-weight:400;
  opacity:.8;
  font-size:.9em;
}

/* Tables */
.table-wrap{overflow-x:auto;}
.table-wide{width:100%;border-collapse:collapse;}
.table-wide th,
.table-wide td{padding:6px 8px;white-space:nowrap;}
.table-wide thead th{font-size:.9rem;border-bottom:1px solid var(--border);}
.table-wide tbody tr:nth-child(even){background:rgba(0,0,0,.02);}

/* =========================================================
   HEADER / NAV (desktop base)
========================================================= */
.site-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:transparent;
}
.site-header .container{
  background:#fff;
  border-radius:16px;
  padding:12px 16px;
  margin:12px auto 8px auto;
  box-shadow:var(--shadow-soft);
}

.site-nav{
  display:flex;
  align-items:center;
  gap:14px;
  background:linear-gradient(90deg,var(--club-green),var(--club-green-2));
  padding:10px 14px;
  border-radius:999px;
}
.site-nav a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#fff;
  text-decoration:none;
  font-weight:800;
  padding:8px 12px;
  border-radius:999px;
}
.site-nav a.active{background:rgba(255,255,255,.22);}
.site-nav .nav-ico{
  width:22px;
  height:22px;
  filter:brightness(0) invert(1);
}

/* =========================================================
   MAIN / HOME GRID
========================================================= */
main.container{margin-top:12px;}

.home-shell{width:100%;}
.home-grid{
  display:grid;
  gap:16px;
}

/* Desktop layout */
@media (min-width:992px){
  .home-grid{
    grid-template-columns:3fr 2fr;
    grid-template-areas:
      "clas calendar"
      "photos top";
    align-items:start;
  }
  .home-grid > .card-soft{min-width:0;}
}

/* Áreas home */
.home-clas{grid-area:clas}
.home-next{grid-area:calendar}
.home-photos{grid-area:photos}
.home-top{grid-area:top}

/* =========================================================
   HOME – Próximos partidos
========================================================= */
#nextMatches .teams-block{
  display:flex;
  flex-direction:column;
  gap:4px;
}
#nextMatches .team-name.team-valldoreix{
  color:var(--club-green);
  font-weight:800;
}

/* HOME – Convocatòria (card) */
#homeConvocatoria:empty{display:none;}
.convocatoria-card .mobile-results{margin-top:6px;}
.convocatoria-card .card-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:10px;
}

/* =========================================================
   TOP (cards base)
========================================================= */
.top3-body{
  display:flex;
  flex-direction:column;
  gap:10px;
}

/* Base per a cards (tant top3-item com top-item) */
.top3-item,
.top-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--border);
}

/* Estils “premium” del top-item (hover + ombra) */
.top-item{
  margin-bottom:6px;
  box-shadow:0 3px 8px rgba(0,0,0,0.08);
  transition:transform .15s ease, box-shadow .15s ease;
}
.top-item:hover{
  transform:translateY(-2px);
  box-shadow:0 5px 12px rgba(0,0,0,0.12);
}

/* Si uses la versió d’una sola línia a la Home */
.top-line{
  display:flex;
  align-items:center;
  width:100%;
  justify-content:space-between;
  font-size:.9rem;
  white-space:nowrap;
}
.top-line span:first-child{
  flex:1;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.top-medal{
  margin-left:auto;
  font-size:1.2rem;
  display:flex;
  align-items:center;
}
.top-footnote{
  margin-top:0;
  padding-top:4px;
  margin-left:6px;
  font-size:.72rem;
  color:#6b7280;
  opacity:.8;
  text-align:left;
}

/* =========================================================
   RANK GRADIENTS (Top 5) — verd intens -> suau
========================================================= */
.rank-1{background:linear-gradient(135deg,#0f5132 0%,#198754 100%);color:#fff;}
.rank-2{background:linear-gradient(135deg,#146c43 0%,#20a56b 100%);color:#fff;}
.rank-3{background:linear-gradient(135deg,#1e7e57 0%,#3dbf88 100%);color:#fff;}
.rank-4{background:linear-gradient(135deg,#3aa777 0%,#7fd6b1 100%);color:#1f1f1f;}
.rank-5{background:linear-gradient(135deg,#6ec8a0 0%,#c7f0df 100%);color:#1f1f1f;}

/* =========================================================
   CALENDARIO – enfrentamiento, badges y chips
========================================================= */
.teams-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.teams{display:grid;gap:2px;line-height:1.15}
.teams .team{font-weight:700}
.teams .vs{font-size:.85em;opacity:.65}

.teams-head-inline{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.teams-inline{
  font-weight:800;
  line-height:1.2;
  white-space:nowrap;
}
.teams-inline .team-inline{font-weight:800}
.teams-inline .sep{opacity:.6;font-weight:700}

/* Score badges */
.score-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:56px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.10);
  background:#fff;
  font-weight:900;
  white-space:nowrap;
}
.score-badge.score-win{
  color:var(--win);
  background:var(--win-bg);
  border-color:rgba(10,122,47,.18);
}
.score-badge.score-lose{
  color:var(--lose);
  background:var(--lose-bg);
  border-color:rgba(180,35,24,.18);
}
.score-badge.score-draw{color:var(--muted);background:rgba(107,114,128,.08)}
.score-badge.score-pending{color:var(--muted);background:rgba(107,114,128,.06)}
.score-badge.score-neutral{color:var(--text);background:#fff}

/* Chips + sets (calendario) */
.mobile-results{
  margin-top:8px;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.match-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.10);
  background:#fff;
  line-height:1.1;
  white-space:nowrap;
}
.match-n{font-weight:800;opacity:.75}
.pair-names{font-weight:700}
.match-chip .sets{display:inline-flex;gap:6px;font-weight:800}

.set{
  padding:2px 6px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.08);
  font-size:.82em;
}
.set-win{
  color:var(--win);
  background:var(--win-bg);
  border-color:rgba(10,122,47,.18);
}
.set-lose{
  color:var(--lose);
  background:var(--lose-bg);
  border-color:rgba(180,35,24,.18);
}
.set-unk{color:var(--muted);background:rgba(107,114,128,.08)}

/* Bordes de match */
.match-win{
  border-color:rgba(10,122,47,.25);
  box-shadow:0 0 0 1px rgba(10,122,47,.10) inset;
}
.match-lose{
  border-color:rgba(180,35,24,.25);
  box-shadow:0 0 0 1px rgba(180,35,24,.10) inset;
}
.match-pending{opacity:.75}

/* Calendario móvil – cards */
.mcal-list{display:grid;gap:10px}
.mcal-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-soft);
  padding:10px 12px;
}
.mcal-line1{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:nowrap;     /* ← canvi clau */
  margin-bottom:6px;
}

.mcal-line1 .ms-auto{
  margin-left:auto;
}.mcal-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:4px 10px;
  border-radius:999px;
  background:rgba(15,107,79,.10);
  color:var(--club-green);
  border:1px solid rgba(15,107,79,.20);
  font-weight:900;
}
.mcal-meta{color:var(--muted);font-weight:700;font-size:.88rem}
.mcal-line2{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  margin-bottom:8px;
}
.mcal-teams{
  font-weight:900;
  line-height:1.2;
  word-break:break-word;
}
.mcal-teams .sep{opacity:.6;font-weight:700}
.mcal-teams-vs{display:grid;gap:2px}
.mcal-vs{font-size:.85em;opacity:.65;font-weight:800}
.mcal-line3 .mcal-chips{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}

/* =========================================================
   CLASIFICACIÓN – MISMO ANCHO (HOME + PÁGINA)
========================================================= */
.home-clas table,
#clasificacionWrap table{
  table-layout:fixed;
  width:100%;
}

/* POS */
.home-clas th:nth-child(1),
.home-clas td:nth-child(1),
#clasificacionWrap th:nth-child(1),
#clasificacionWrap td:nth-child(1){
  width:var(--clas-col-pos);
  text-align:center;
}

/* EQUIPO */
.home-clas th:nth-child(2),
.home-clas td:nth-child(2),
#clasificacionWrap th:nth-child(2),
#clasificacionWrap td:nth-child(2){
  width:auto;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

/* PTS */
.home-clas th:nth-child(3),
.home-clas td:nth-child(3),
#clasificacionWrap th:nth-child(3),
#clasificacionWrap td:nth-child(3){
  width:var(--clas-col-pts);
  text-align:center;
}

/* J / G / P */
.home-clas th:nth-child(4),
.home-clas td:nth-child(4),
.home-clas th:nth-child(5),
.home-clas td:nth-child(5),
.home-clas th:nth-child(6),
.home-clas td:nth-child(6),
#clasificacionWrap th:nth-child(4),
#clasificacionWrap td:nth-child(4),
#clasificacionWrap th:nth-child(5),
#clasificacionWrap td:nth-child(5),
#clasificacionWrap th:nth-child(6),
#clasificacionWrap td:nth-child(6){
  width:var(--clas-col-num);
  text-align:center;
}

/* =========================================================
   RESALTADO VALLDOREIX (HOME + CLASIFICACIÓN)
========================================================= */
.is-valldoreix{background:rgba(15,107,79,.10);}
.is-valldoreix td{font-weight:400;}
.is-valldoreix td:nth-child(2){
  color:var(--club-green);
  font-weight:800;
}
.is-valldoreix td.col-pts{font-weight:800;}

/* =========================================================
   MOBILE (UNIFICADO)
========================================================= */
@media (max-width:768px){
  main.container,
  .container.my-4{
    max-width:var(--app-max);
    margin-left:auto;
    margin-right:auto;
    padding-left:16px;
    padding-right:16px;
    padding-bottom:calc(16px + 86px + env(safe-area-inset-bottom));
  }

  .site-header .container{
    max-width:var(--app-max);
    gap:10px;
    justify-content:space-between;
  }

  body{
    padding-bottom:calc(86px + env(safe-area-inset-bottom));
  }

  .home-shell,
  .home-grid{
    width:100%;
    max-width:100%;
  }

  .home-grid{grid-template-columns:1fr;}

  /* Nav inferior fijo */
  .site-nav{
    position:fixed !important;
    left:0 !important;
    right:0 !important;
    top:auto !important;
    bottom:0 !important;
    border-radius:0 !important;
    justify-content:space-around !important;
    z-index:2000 !important;
  }
  .site-nav .nav-txt{display:none !important;}
  .site-nav .nav-ico{width:26px !important;height:26px !important;}

  /* Estadísticas – móvil */
  #statsHead,#statsBody{white-space:nowrap;}

  table:has(#statsHead){
    table-layout:fixed;
    width:100%;
  }

  table:has(#statsHead) th:nth-child(1),
  table:has(#statsHead) td:nth-child(1){
    width:auto;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }

  /* La resta de columnes */
  table:has(#statsHead) th:nth-child(n+2),
  table:has(#statsHead) td:nth-child(n+2){
    width:38px;
    font-size:.9rem;
    text-align:center;
  }

  table:has(#statsHead) th,
  table:has(#statsHead) td{
    padding:6px 6px;
    font-size:.92rem;
  }

  /* Jugador més gran */
  table:has(#statsHead) td:nth-child(1),
  table:has(#statsHead) th:nth-child(1){
    font-size:1rem;
    font-weight:800;
  }

  /* Columnes numèriques una mica més petites */
  table:has(#statsHead) td:nth-child(n+2),
  table:has(#statsHead) th:nth-child(n+2){
    font-size:.85rem;
  }

  /* elements visibles només a desktop */
  .only-desktop{display:none !important;}

  /* Logout: botó gran verd en mòbil (capçalera) */
  #logoutBtn{
    margin-left:auto;
    width:48px;
    height:48px;
    border:none;
    background:var(--club-green);
    color:#fff;
    box-shadow:0 4px 12px rgba(0,0,0,.25);
  }
  #logoutBtn:hover{background:var(--club-green-2);}
}

/* elements visibles només a desktop */
.only-desktop{display:inline-flex;}

/* =========================================================
   LOGIN (mobile-first)
========================================================= */
.login-body{
  min-height:100vh;
  background:
    radial-gradient(1200px 600px at 20% -10%, rgba(15,107,79,.18), transparent 55%),
    radial-gradient(900px 500px at 120% 10%, rgba(15,107,79,.12), transparent 55%),
    var(--bg);
  display:flex;
  align-items:center;
  justify-content:center;
}
.login-shell{
  width:100%;
  max-width:520px;
  padding:18px;
}
.login-card{
  width:100%;
  box-shadow:var(--shadow-soft);
  padding:18px;
}
.login-head{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:12px;
}
.login-logo{
  width:56px;
  height:56px;
  border-radius:14px;
  object-fit:contain;
  background:#fff;
  border:1px solid var(--border);
  padding:6px;
}
.login-titles{line-height:1.15;}
.login-title{font-weight:900;font-size:1.25rem;}
.login-subtitle{
  color:var(--muted);
  font-weight:800;
  font-size:.95rem;
  margin-top:2px;
}
.login-msg{
  min-height:20px;
  margin:6px 0 10px 0;
  font-weight:800;
  color:var(--lose);
}
.login-form{display:grid;gap:8px;}
.login-label{
  font-size:.85rem;
  color:var(--muted);
  font-weight:800;
  margin-top:6px;
}
.login-input{
  width:100%;
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px 12px;
  font-weight:700;
  outline:none;
  background:#fff;
}
.login-input:focus{
  border-color:rgba(15,107,79,.45);
  box-shadow:0 0 0 4px rgba(15,107,79,.10);
}
.login-passwrap{position:relative;}
.login-peek{
  position:absolute;
  right:8px;
  top:50%;
  transform:translateY(-50%);
  border:0;
  background:transparent;
  padding:6px 8px;
  border-radius:10px;
  cursor:pointer;
  opacity:.8;
}
.login-peek:hover{opacity:1;background:rgba(0,0,0,.04);}
.login-btn{
  margin-top:10px;
  border:0;
  border-radius:14px;
  padding:12px 14px;
  font-weight:900;
  color:#fff;
  background:linear-gradient(90deg,var(--club-green),var(--club-green-2));
  box-shadow:0 10px 22px rgba(15,107,79,.18);
}
.login-btn:active{transform:translateY(1px);}
.login-foot{
  margin-top:12px;
  font-size:.85rem;
  display:flex;
  justify-content:center;
}
@media (min-width:992px){
  .login-card{padding:22px;}
  .login-logo{width:64px;height:64px;}
  .login-title{font-size:1.35rem;}
}

/* =========================================================
   UTILIDADES / LEGACY
========================================================= */
.partido{margin-bottom:12px;}
.resultado{font-size:1.2em;font-weight:bold;margin-top:4px;}
.refresh{font-size:.8em;opacity:.6;text-align:center;}

.badge-online{
  padding:3px 10px;
  border-radius:999px;
  font-size:.78rem;
  font-weight:700;
  color:var(--win);
  background:var(--win-bg);
  text-decoration:none;
  white-space:nowrap;
}
.badge-online:hover{background:#d2f0dd;}

/* =========================================================
   ONLINE (sets + cards + header equipos)
========================================================= */
.sets-row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.set-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:48px;
  padding:6px 8px;
  border-radius:12px;
  font-weight:800;
  font-size:.9rem;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 1px 0 rgba(0,0,0,.03);
}
.set-pill.set-win{background:var(--win-bg);color:var(--win);}
.set-pill.set-lose{background:var(--lose-bg);color:var(--lose);}
.set-pill.set-neutral{background:#f2f4f7;color:#344054;}

.pair-card{
  border-radius:14px;
  transition:background .15s ease,border-color .15s ease;
}
.pair-card.pair-win{
  border:1px solid rgba(10,122,47,.25);
  background:linear-gradient(0deg, rgba(230,246,236,.7), rgba(255,255,255,1));
}
.pair-card.pair-lose{
  border:1px solid rgba(180,35,24,.25);
  background:linear-gradient(0deg, rgba(253,232,232,.75), rgba(255,255,255,1));
}
.pair-card.pair-neutral{border:1px solid rgba(0,0,0,.08);}

.pair-status{
  font-size:.85rem;
  font-weight:700;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.06);
  background:#f2f4f7;
  color:#344054;
}
.pair-status.pair-win{
  background:var(--win-bg);
  color:var(--win);
  border-color:rgba(10,122,47,.18);
}
.pair-status.pair-lose{
  background:var(--lose-bg);
  color:var(--lose);
  border-color:rgba(180,35,24,.18);
}

.ol-teamrow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.07);
  background:#fff;
  margin-top:6px;
}
.ol-teamname{font-weight:700;line-height:1.2;}
.ol-teampoints{
  min-width:34px;
  text-align:center;
  font-weight:900;
  font-size:1rem;
  border-radius:999px;
  padding:4px 8px;
  background:#f2f4f7;
}

/* ONLINE – capçalera Jornada més compacta */
#olJornadaCard{
  padding:10px 12px !important; /* sobreescriu p-3 */
}
#olJornadaCard .h6{
  font-size:1.05rem;
  margin:0 0 2px 0 !important;
  line-height:1.15;
}
#olJornadaCard .text-muted.small{
  margin:0 !important;
  line-height:1.2;
}
#olJornadaCard .mb-1{ margin-bottom:4px !important; }
#olJornadaCard .ol-teamrow{ margin-top:4px !important; }

/* ONLINE – ALINEAR BOTONES MOSTRAR/OCULTAR */
.ol-card-head{align-items:flex-start !important;}
.ol-card-head h2{margin:0 !important;line-height:1.15;}
.ol-card-head .text-muted{margin-top:4px;}
.ol-card-head .ol-toggle-btn{margin-top:2px;min-width:92px;}

/* =========================================================
   FIX CALENDARIO: garantizar sets en verde/rojo
========================================================= */
.match-chip .set-win,
.match-chip .set.set-win{
  color:var(--win) !important;
  background:var(--win-bg) !important;
  border-color:rgba(10,122,47,.18) !important;
}
.match-chip .set-lose,
.match-chip .set.set-lose{
  color:var(--lose) !important;
  background:var(--lose-bg) !important;
  border-color:rgba(180,35,24,.18) !important;
}
.match-chip.match-win{
  border-color:rgba(10,122,47,.25) !important;
  box-shadow:0 0 0 1px rgba(10,122,47,.10) inset !important;
}
.match-chip.match-lose{
  border-color:rgba(180,35,24,.25) !important;
  box-shadow:0 0 0 1px rgba(180,35,24,.10) inset !important;
}

/* =========================================================
   LOGOUT (base + SVG)
========================================================= */
.logout-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.10);
  background:#fff;
  color:var(--text);
  font-weight:900;
  cursor:pointer;
  box-shadow:0 2px 8px rgba(0,0,0,.06);
}
.logout-btn:hover{background:rgba(0,0,0,.03);}
.logout-btn:active{transform:scale(.97);}

.logout-ico{
  width:22px;
  height:22px;
  filter:brightness(0) invert(1);
}
@media (max-width:768px){
  .logout-ico{width:24px;height:24px;}
}
#logoutBtn:hover .logout-ico{transform:rotate(-15deg);}
#logoutBtn:active .logout-ico{transform:scale(.9);}

/* =========================================================
   CAROUSEL (desktop)
========================================================= */
@media (min-width:992px){
  .carousel-compact .carousel-item img{
    height:auto;
    max-height:420px;
    object-fit:contain;
  }
}

/* =========================================================
   CHAT (online)
========================================================= */
#olChatMessages{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:8px;
  max-height:350px;
  overflow-y:auto;
}
.chat-row{display:flex;justify-content:flex-start;}
.chat-row.mine{justify-content:flex-end;}
.chat-bubble{
  max-width:75%;
  padding:8px 12px;
  border-radius:16px;
  background:#f1f1f1;
  font-size:.9rem;
  position:relative;
}
.chat-row.mine .chat-bubble{background:#dcf8c6;}
.chat-name{font-size:.7rem;font-weight:600;margin-bottom:2px;opacity:.6;}
.chat-text{word-wrap:break-word;}
.chat-time{font-size:.65rem;text-align:right;margin-top:4px;opacity:.5;}

/* =========================================================
   UNIFICAR TÍTULOS DE TODAS LAS CARDS
========================================================= */
.card-soft .card-header h3{
  margin:0;
  font-size:18px;
  font-weight:800;
  line-height:1.2;
}

/* =========================================================
   CAPITÁN
   - Base “neutral” per no trepitjar parelles (que van amb grid)
========================================================= */

/* Parelles: SEMPRE 1 línia (nº + 2 selects) */
#olCaptainPairs .ol-cap-row{
  display:grid !important;
  grid-template-columns:20px 1fr 1fr;
  gap:8px;
  align-items:center;
}
#olCaptainPairs .ol-cap-row .ol-cap-input{
  width:100% !important;
  max-width:100% !important;
}

/* =========================================================
   CALENDARIO (móvil) — nombres completos arriba + sets centrados abajo
========================================================= */
@media (max-width:768px){

  .mcal-card .match-chip{
    display:flex !important;
    flex-wrap:wrap !important;
    align-items:center;
    gap:8px;
    width:100% !important;
    padding:6px 8px !important;
  }

  .mcal-card .match-chip .match-n{
    flex:0 0 auto;
    white-space:nowrap;
  }

  .mcal-card .match-chip .pair-names{
    flex:1 1 auto;
    min-width:0;
    font-weight:400 !important;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .mcal-card .match-chip .sets{
    flex:0 0 100%;
    display:flex !important;
    justify-content:center;
    gap:6px;
    margin-top:6px;
    white-space:nowrap;
  }

  .mcal-card .match-chip .set{
    font-size:.80em;
    padding:2px 6px;
  }

  .mcal-card .mobile-results{
    padding-left:0 !important;
    padding-right:0 !important;
  }
}

/* === Toggle button uniforme a totes les cards === */
.ol-toggle-btn{
  min-width:110px !important;
  padding: .35rem .85rem !important;
  font-size: .95rem !important;
  line-height: 1.1 !important;
  border-width: 2px !important;
  border-radius: .6rem !important;
  opacity: 1 !important;
}

/* === Capçalera uniforme === */
.ol-card-head{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:12px !important;
}

/* =========================================================
   JORNADA · RESULTADOS (Capità)
   - cards Pareja més compactes
   - "Pareja X" en negreta
   - inputs sets a la meitat (ample)
========================================================= */

.ol-cap-match{
  /* card més “estret/compacte” */
  padding: .55rem .6rem !important;
  border-radius: 12px;
}

.ol-cap-title{
  font-weight: 800;        /* "Pareja 1" en negreta */
  margin-bottom: .15rem;
}

.ol-cap-names{
  font-size: .92rem;       /* una mica més compacte */
  line-height: 1.15;
  margin-bottom: .35rem;
}

.ol-cap-inputs{
  gap: .35rem !important;
  justify-content: flex-start;
}

.ol-cap-set{
  /* inputs del resultat a la meitat */
  width: 56px;             /* ajusta a 52–60 si vols */
  max-width: 56px;
  text-align: center;
  padding: .2rem .35rem;
}

.login-logo {
  width: 80px;
  height: auto;
  display: block;
  margin: 0 auto 25px auto;
}

@media (max-width: 576px) {
  .login-logo {
    width: 80px;
  }
}

.ol-stepper {
  display:flex;
  align-items:center;
  gap:4px;
}

.ol-stepper input {
  width:40px;
  text-align:center;
  border:1px solid #ddd;
  border-radius:6px;
}

.ol-stepper button {
  width:30px;
  height:30px;
  border:none;
  border-radius:6px;
  background:#0f6b4f;
  color:white;
  font-weight:bold;
}

.ol-stepper button:active {
  transform:scale(.95);
}

/* =========================================================
   JORNADA (Capitán) — compact UI (móvil)
========================================================= */
.ol-jcompact{padding:4px 0;}
.ol-jline1{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:nowrap;
}
.ol-jline2{
  margin-left:52px; /* aligns under teams (approx tag width) */
  line-height:1.1;
}
.ol-jtag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:4px 10px;
  border-radius:999px;
  background:rgba(15,107,79,.10);
  color:var(--club-green);
  border:1px solid rgba(15,107,79,.22);
  font-weight:900;
  white-space:nowrap;
  flex-shrink:0;
}
.ol-jteam{
  font-weight:900;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  min-width:0;
}
.ol-jvs{opacity:.55;font-weight:900;margin:0 2px;}

/* WhatsApp buttons (Enviar whats / Enviar convo) */
.btn-whatsapp{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:10px !important;
  border:0 !important;
  border-radius:14px !important;
  padding:.55rem .9rem !important;
  font-weight:900 !important;
  color:#fff !important;
  background:#25D366 !important;
  box-shadow:0 6px 16px rgba(0,0,0,.12);
}
.btn-whatsapp:hover{filter:brightness(.96);}
.btn-whatsapp:active{transform:translateY(1px);}
.btn-whatsapp .wa-ico{width:18px;height:18px;display:block;}
.btn-whatsapp .wa-txt{white-space:nowrap;}



/* ===== Resultados compact v2 ===== */
.ol-cap-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.ol-cap-left{
  min-width:0;
}
.ol-cap-p{
  font-weight:1000;
  font-size:1.05rem;
  line-height:1.1;
}
.ol-cap-n{
  font-weight:800;
  font-size:.95rem;
  line-height:1.1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:52vw;
}

.ol-set-tabs{
  display:flex;
  gap:8px;
  align-items:flex-start;
  justify-content:flex-end;
  flex-shrink:0;
}
.ol-set-chip{
  width:52px;
  border-radius:999px;
  padding:8px 6px;
}
.ol-set-chip .ol-chip-score{
  display:block;
  font-weight:1000;
  font-size:1.05rem;
  line-height:1.05;
}
.ol-set-chip .ol-chip-num{
  display:block;
  margin-top:2px;
  font-weight:900;
  font-size:.85rem;
  opacity:.75;
  line-height:1;
}

.ol-set-controls{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding-top:6px;
}
.ol-stepper-btns{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:6px 6px 4px 6px;
  border-radius:14px;
  background:rgba(0,0,0,.02);
  flex:1;
}
.ol-stepper-btns .ol-stepper-row{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}
.ol-stepper-btns .ol-step{
  width:44px;
  height:44px;
  border-radius:14px;
  font-size:1.35rem;
}
.ol-stepper-btns .ol-stepper-lab{
  font-weight:900;
  font-size:.85rem;
  opacity:.8;
  line-height:1;
}
.ol-step-val-hidden{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0,0,0,0) !important;
  white-space:nowrap !important;
  border:0 !important;
}


/* === Appadel Captain - Alineación (mobile first) === */
#olCaptainPairsActions{
  display:flex;
  gap:.5rem;
  flex-wrap:nowrap; /* keep in one line on mobile */
}
#olCaptainPairsActions > button{
  flex:1 1 0;
  padding:.38rem .55rem;
  font-size:.85rem;
  line-height:1.1;
}
@media (max-width: 420px){
  #olCaptainPairsActions > button{
    padding:.34rem .45rem;
    font-size:.82rem;
  }
}

.ol-align-locked-msg{
  font-size:.92rem;
  font-weight:700;
  text-align:center;
  padding:.6rem .6rem;
  border-radius:12px;
  background:rgba(220,53,69,.10);
  color:#842029;
}
