/* ================================================================
   Calcio Finder v1.0.0 – Premium UI
   Palette: #111827 dark | #2ecc71 green | #f1c40f gold | #e74c3c red
   ================================================================ */
:root{
  --cf-dark:#111827;--cf-dark2:#1f2937;--cf-dark3:#374151;
  --cf-green:#2ecc71;--cf-green2:#27ae60;
  --cf-yellow:#f1c40f;--cf-red:#e74c3c;--cf-blue:#3498db;--cf-purple:#9b59b6;
  --cf-bg:#f3f4f6;--cf-white:#fff;--cf-border:#e5e7eb;
  --cf-text:#111827;--cf-muted:#6b7280;
  --cf-r:12px;--cf-shadow:0 4px 20px rgba(0,0,0,.1);
  --calcio-accent:var(--e-global-color-accent,#2ecc71);
  --calcio-bg:var(--e-global-color-secondary,#fff);
  --calcio-radius:var(--cf-r);--calcio-shadow:var(--cf-shadow);
}
*{box-sizing:border-box}
.calcio-muted{color:var(--cf-muted)}
.calcio-link{color:var(--cf-green);text-decoration:none;font-weight:700}
.calcio-link:hover{text-decoration:underline}

/* ──────────────────────────────────────────────────────────────
   GLOBAL SEARCH – buscador autocomplete universal
   ────────────────────────────────────────────────────────────── */
.cf-search{position:relative;width:100%}
.cf-search__bar{
  display:flex;align-items:center;gap:.6rem;border-radius:99px;
  padding:.2rem .2rem .2rem 1.2rem;transition:border-color .2s,box-shadow .2s;
}
.cf-search--dark .cf-search__bar{
  background:var(--cf-dark);border:2px solid rgba(46,204,113,.3);
  box-shadow:0 6px 28px rgba(0,0,0,.28);
}
.cf-search--dark .cf-search__bar:focus-within{border-color:var(--cf-green)}
.cf-search:not(.cf-search--dark) .cf-search__bar{
  background:#fff;border:2px solid var(--cf-border);box-shadow:var(--cf-shadow);
}
.cf-search:not(.cf-search--dark) .cf-search__bar:focus-within{border-color:var(--cf-green)}
.cf-search__ico{font-size:1.05rem;flex-shrink:0}
.cf-search__input{
  flex:1;border:none;outline:none;background:transparent;
  font-size:1rem;padding:.8rem 0;
}
.cf-search--dark .cf-search__input{color:#fff}
.cf-search--dark .cf-search__input::placeholder{color:rgba(255,255,255,.35)}
.cf-search:not(.cf-search--dark) .cf-search__input{color:var(--cf-text)}
.cf-search:not(.cf-search--dark) .cf-search__input::placeholder{color:var(--cf-muted)}
.cf-search__clear{
  width:30px;height:30px;border-radius:50%;border:none;cursor:pointer;
  font-size:.8rem;flex-shrink:0;transition:background .15s;
}
.cf-search--dark .cf-search__clear{background:rgba(255,255,255,.1);color:rgba(255,255,255,.7)}
.cf-search:not(.cf-search--dark) .cf-search__clear{background:var(--cf-bg);color:var(--cf-muted)}
/* Dropdown */
.cf-search__drop{
  position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:9999;
  border-radius:16px;overflow:hidden;max-height:480px;overflow-y:auto;
}
.cf-search--dark .cf-search__drop{
  background:var(--cf-dark2);border:1px solid rgba(255,255,255,.1);
  box-shadow:0 16px 56px rgba(0,0,0,.45);
}
.cf-search:not(.cf-search--dark) .cf-search__drop{
  background:#fff;border:1px solid var(--cf-border);box-shadow:var(--cf-shadow);
}
.cf-ac-group-title{
  display:flex;align-items:center;gap:.4rem;padding:.6rem 1rem .25rem;
  font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;
  border-top:1px solid rgba(255,255,255,.06);
}
.cf-ac-group:first-child .cf-ac-group-title{border-top:none}
.cf-search--dark .cf-ac-group-title{color:rgba(255,255,255,.35)}
.cf-search:not(.cf-search--dark) .cf-ac-group-title{color:var(--cf-muted);border-color:var(--cf-border)}
.cf-ac-item{
  display:flex;align-items:center;gap:.75rem;padding:.55rem 1rem;
  text-decoration:none;transition:background .12s;
}
.cf-search--dark .cf-ac-item:hover{background:rgba(255,255,255,.07)}
.cf-search:not(.cf-search--dark) .cf-ac-item:hover{background:var(--cf-bg)}
.cf-ac-thumb{
  width:34px;height:34px;border-radius:9px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:.95rem;
}
.cf-search--dark .cf-ac-thumb{background:rgba(255,255,255,.08)}
.cf-search:not(.cf-search--dark) .cf-ac-thumb{background:var(--cf-bg)}
.cf-ac-info{min-width:0}
.cf-ac-name{font-size:.9rem;font-weight:700;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cf-ac-meta{font-size:.72rem;margin-top:.1rem}
.cf-search--dark .cf-ac-name{color:#fff}
.cf-search--dark .cf-ac-meta{color:rgba(255,255,255,.4)}
.cf-search:not(.cf-search--dark) .cf-ac-name{color:var(--cf-text)}
.cf-search:not(.cf-search--dark) .cf-ac-meta{color:var(--cf-muted)}
.cf-ac-empty{padding:1.5rem;text-align:center;font-size:.88rem}
.cf-search--dark .cf-ac-empty{color:rgba(255,255,255,.4)}
.cf-search:not(.cf-search--dark) .cf-ac-empty{color:var(--cf-muted)}

/* ──────────────────────────────────────────────────────────────
   LEAGUE SEARCH – filtros en cascada
   ────────────────────────────────────────────────────────────── */
.cf-league{font-family:inherit;color:var(--cf-text)}
.cf-league__hero{
  display:flex;align-items:center;justify-content:space-between;
  background:linear-gradient(135deg,var(--cf-dark) 0%,#16213e 100%);
  border-radius:16px 16px 0 0;padding:1.75rem 2rem 1.5rem;color:#fff;
}
.cf-league__title{font-size:clamp(1.3rem,3vw,1.9rem);font-weight:900;margin:0 0 .3rem;letter-spacing:-.02em}
.cf-league__sub{margin:0;font-size:.82rem;color:rgba(255,255,255,.5)}
.cf-league__hero-ico{font-size:3.2rem;opacity:.14;flex-shrink:0}
.cf-league__filters{
  background:#fff;border:1px solid var(--cf-border);border-top:none;
  border-radius:0 0 16px 16px;padding:1.5rem;box-shadow:var(--cf-shadow);margin-bottom:1.5rem;
}
.cf-league__row{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
  gap:1rem;margin-bottom:1rem;
}
.cf-league__field{display:flex;flex-direction:column;gap:.3rem}
.cf-league__field--wide{flex:2}
.cf-league__lbl{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--cf-muted)}
.cf-league__sel,.cf-league__input{
  width:100%;border:1.5px solid var(--cf-border);border-radius:9px;
  padding:.58rem .85rem;font-size:.9rem;color:var(--cf-text);
  background:var(--cf-bg);transition:border-color .2s,box-shadow .2s;
  appearance:none;-webkit-appearance:none;
}
.cf-league__sel{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath fill='%236b7280' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .8rem center;padding-right:2.2rem;
}
.cf-league__sel:focus,.cf-league__input:focus{
  border-color:var(--cf-green);outline:none;box-shadow:0 0 0 3px rgba(46,204,113,.12);
}
.cf-league__sel:disabled{opacity:.45;cursor:not-allowed;background:var(--cf-border)}
.cf-league__actions{
  display:flex;align-items:center;flex-wrap:wrap;gap:.65rem;
  padding-top:1rem;border-top:1px solid var(--cf-border);
}
.cf-league__btn{
  display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.4rem;
  border-radius:99px;border:2px solid var(--cf-dark);
  background:var(--cf-dark);color:var(--cf-green);
  font-size:.88rem;font-weight:800;cursor:pointer;transition:opacity .18s;
}
.cf-league__btn:hover{opacity:.85}
.cf-league__btn--ghost{background:transparent;color:var(--cf-text);border-color:var(--cf-border)}
.cf-league__btn--ghost:hover{border-color:var(--cf-dark);color:var(--cf-dark)}
.cf-league__count{margin-left:auto;font-size:.8rem;color:var(--cf-muted);font-weight:600}
/* Loading */
.cf-league__loading{
  display:flex;align-items:center;gap:.75rem;justify-content:center;
  padding:2.5rem;color:var(--cf-muted);font-size:.9rem;
}
.cf-spinner{
  width:24px;height:24px;border-radius:50%;
  border:3px solid var(--cf-border);border-top-color:var(--cf-green);
  animation:cf-spin .7s linear infinite;flex-shrink:0;
}
@keyframes cf-spin{to{transform:rotate(360deg)}}
/* Empty */
.cf-league__empty{
  padding:3.5rem 2rem;text-align:center;color:var(--cf-muted);
  background:#fff;border-radius:14px;border:1px solid var(--cf-border);
}
.cf-league__empty-ico{font-size:3rem;opacity:.3;margin-bottom:.75rem}
.cf-league__empty p{margin:0;font-size:.95rem}
/* Results grid */
.cf-league__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}
/* Competition card */
.cf-comp-card{
  display:flex;flex-direction:column;background:#fff;
  border:1px solid var(--cf-border);border-radius:14px;
  padding:1.2rem;text-decoration:none;color:var(--cf-text);
  position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s,border-color .2s;
}
.cf-comp-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--cf-green),var(--cf-blue));
  transform:scaleX(0);transform-origin:left;transition:transform .3s;
}
.cf-comp-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,.12);border-color:rgba(46,204,113,.35);color:var(--cf-text)}
.cf-comp-card:hover::before{transform:scaleX(1)}
.cf-comp-card__head{display:flex;align-items:flex-start;gap:.85rem;margin-bottom:.85rem}
.cf-comp-card__icon{
  width:42px;height:42px;border-radius:11px;flex-shrink:0;
  background:linear-gradient(135deg,var(--cf-dark),var(--cf-dark2));
  display:flex;align-items:center;justify-content:center;font-size:1.2rem;
}
.cf-comp-card__name{font-size:.97rem;font-weight:800;line-height:1.25;margin-bottom:.2rem}
.cf-comp-card__season{font-size:.75rem;color:var(--cf-muted)}
.cf-comp-card__tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.85rem}
.cf-tag{
  display:inline-flex;align-items:center;gap:.2rem;
  padding:.18rem .55rem;border-radius:99px;
  font-size:.7rem;font-weight:700;background:var(--cf-bg);color:var(--cf-muted);
}
.cf-tag.green{background:rgba(46,204,113,.12);color:#1a7d42}
.cf-tag.pink{background:rgba(231,76,60,.1);color:#922b21}
.cf-tag.blue{background:rgba(52,152,219,.1);color:#1a5276}
.cf-tag.dark{background:var(--cf-dark);color:var(--cf-green)}
.cf-tag.gold{background:rgba(241,196,15,.15);color:#7d6600}
.cf-comp-card__footer{
  margin-top:auto;display:flex;align-items:center;justify-content:space-between;
  padding-top:.75rem;border-top:1px solid var(--cf-border);font-size:.78rem;color:var(--cf-muted);
}
.cf-comp-card__cta{color:var(--cf-green);font-weight:700}
/* Pager */
.cf-league__pager{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem}
.cf-league__page-info{font-size:.83rem;color:var(--cf-muted);font-weight:600}

/* ──────────────────────────────────────────────────────────────
   PROFILES – fichas detalladas
   ────────────────────────────────────────────────────────────── */
.calcio-profile{color:var(--cf-text)}
.calcio-card{background:var(--calcio-bg,#fff);border:1px solid var(--cf-border);border-radius:var(--calcio-radius);box-shadow:var(--calcio-shadow);overflow:hidden}
/* Hero */
.calcio-hero{
  background:linear-gradient(140deg,var(--cf-dark) 0%,#16213e 100%);
  padding:2rem 2rem 0;position:relative;overflow:hidden;
}
.calcio-hero::before{
  content:'';position:absolute;top:-60px;right:-60px;width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle,rgba(46,204,113,.1) 0%,transparent 70%);pointer-events:none;
}
.calcio-hero__left{display:flex;align-items:flex-start;gap:1.25rem;position:relative;z-index:1}
.calcio-avatar{
  width:76px;height:76px;border-radius:50%;flex-shrink:0;
  border:2px solid rgba(46,204,113,.4);background:rgba(46,204,113,.1);
  display:flex;align-items:center;justify-content:center;
  font-size:1.9rem;font-weight:900;color:var(--cf-green);
}
.calcio-logo{width:76px;height:76px;border-radius:12px;flex-shrink:0;background:rgba(255,255,255,.1);overflow:hidden;display:flex;align-items:center;justify-content:center}
.calcio-logo img{max-width:100%;max-height:100%;object-fit:contain}
.calcio-h{font-size:clamp(1.25rem,3vw,1.9rem);font-weight:900;color:#fff;margin:0 0 .5rem;letter-spacing:-.02em;line-height:1.1}
.calcio-badges{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}
.calcio-badge{
  display:inline-flex;align-items:center;padding:.2rem .65rem;border-radius:99px;
  font-size:.7rem;font-weight:700;background:rgba(255,255,255,.12);
  color:rgba(255,255,255,.88);border:1px solid rgba(255,255,255,.15);
}
.calcio-badge--soft{background:rgba(46,204,113,.2);border-color:rgba(46,204,113,.4);color:#2ecc71}
/* Stats bar inside hero bottom */
.calcio-statbar{
  display:flex;flex-wrap:wrap;background:rgba(255,255,255,.05);
  border-top:1px solid rgba(255,255,255,.08);margin:1.5rem -2rem 0;
}
.calcio-stat{flex:1;min-width:80px;text-align:center;padding:.9rem .5rem;border-right:1px solid rgba(255,255,255,.06)}
.calcio-stat:last-child{border-right:none}
.calcio-stat__val{font-size:1.5rem;font-weight:900;line-height:1;color:var(--cf-green)}
.calcio-stat__val.y{color:var(--cf-yellow)}
.calcio-stat__val.r{color:var(--cf-red)}
.calcio-stat__val.b{color:var(--cf-blue)}
.calcio-stat__val.w{color:#fff}
.calcio-stat__lbl{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.4);margin-top:.2rem}
/* Tabs */
.calcio-tab-nav{
  display:flex;flex-wrap:wrap;background:var(--cf-bg);
  border-bottom:2px solid var(--cf-border);padding:0 1.5rem;
}
.calcio-tab{
  padding:.82rem 1.1rem;border:none;background:transparent;
  font-size:.82rem;font-weight:700;color:var(--cf-muted);cursor:pointer;
  border-bottom:2.5px solid transparent;margin-bottom:-2px;
  transition:color .18s,border-color .18s;white-space:nowrap;
}
.calcio-tab:hover{color:var(--cf-text)}
.calcio-tab[aria-selected="true"]{color:var(--cf-dark);border-bottom-color:var(--cf-green)}
.calcio-panel{display:none;padding:1.5rem}
.calcio-panel.is-active{display:block}
/* Key-value */
.calcio-kv{width:100%;border-collapse:collapse;font-size:.9rem}
.calcio-kv th{padding:.6rem .85rem;text-align:left;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--cf-muted);background:var(--cf-bg);border-bottom:1px solid var(--cf-border);white-space:nowrap;width:155px}
.calcio-kv td{padding:.6rem .85rem;border-bottom:1px solid var(--cf-border);font-weight:500}
.calcio-kv tr:last-child th,.calcio-kv tr:last-child td{border-bottom:none}
/* Data tables */
.calcio-table-wrap{overflow-x:auto}
.calcio-table{width:100%;border-collapse:collapse;font-size:.87rem}
.calcio-table thead tr{background:var(--cf-dark)}
.calcio-table th{padding:.65rem 1rem;text-align:left;color:rgba(255,255,255,.65);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;white-space:nowrap}
.calcio-table td{padding:.65rem 1rem;border-bottom:1px solid var(--cf-border);vertical-align:middle}
.calcio-table tr:last-child td{border-bottom:none}
.calcio-table tbody tr:hover td{background:rgba(46,204,113,.03)}
/* Standings zones */
.calcio-table .pos-top td:first-child{border-left:3px solid var(--cf-green)}
.calcio-table .pos-bot td:first-child{border-left:3px solid var(--cf-red)}
.calcio-table .pts{font-weight:900;font-size:.95rem}
.ico-g{color:var(--cf-green)}
.ico-y{display:inline-block;width:10px;height:14px;background:var(--cf-yellow);border-radius:2px;vertical-align:middle}
.ico-r{display:inline-block;width:10px;height:14px;background:var(--cf-red);border-radius:2px;vertical-align:middle}
/* Standings legend */
.cf-standings-legend{
  display:flex;align-items:center;gap:.5rem;
  padding:.65rem 1rem;background:var(--cf-bg);border-top:1px solid var(--cf-border);
  font-size:.72rem;color:var(--cf-muted);
}
.cf-leg{display:inline-block;width:12px;height:12px;border-radius:2px}
.cf-leg--green{background:var(--cf-green)}
.cf-leg--red{background:var(--cf-red)}

/* Match results cards */
.cf-results{display:flex;flex-direction:column;gap:.5rem}
.cf-results__jornada{
  font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;
  color:var(--cf-muted);padding:.5rem 0 .25rem;border-bottom:1px solid var(--cf-border);
  margin-top:.75rem;
}
.cf-results__jornada:first-child{margin-top:0}
.cf-match{
  background:#fff;border:1px solid var(--cf-border);border-radius:12px;
  padding:.85rem 1.1rem;
}
.cf-match__date{font-size:.72rem;color:var(--cf-muted);margin-bottom:.5rem}
.cf-match__body{display:flex;align-items:center;gap:.65rem}
.cf-match__team{flex:1;font-size:.92rem;font-weight:700;color:var(--cf-text)}
.cf-match__team--local{text-align:right}
.cf-match__team--visit{text-align:left}
.cf-match__team--win{color:var(--cf-green)}
.cf-match__score{
  background:var(--cf-dark);color:#fff;border-radius:8px;
  padding:.25rem .85rem;font-weight:900;font-size:1.05rem;
  white-space:nowrap;text-align:center;min-width:68px;flex-shrink:0;
}
.cf-match__score--pending{background:var(--cf-bg);color:var(--cf-muted);font-weight:700}
.cf-match__foot{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--cf-border);
  font-size:.75rem;
}

/* ──────────────────────────────────────────────────────────────
   PROFILE TEMPLATE overrides (tabs inside profile)
   ────────────────────────────────────────────────────────────── */
.calcio-tabs{display:flex;flex-direction:column}

/* ──────────────────────────────────────────────────────────────
   RESPONSIVE
   ────────────────────────────────────────────────────────────── */
@media(max-width:720px){
  .cf-league__hero{border-radius:12px 12px 0 0;padding:1.4rem 1.2rem 1.2rem}
  .cf-league__title{font-size:1.3rem}
  .cf-league__row{grid-template-columns:1fr}
  .cf-league__actions{flex-direction:column;align-items:stretch}
  .cf-league__btn{justify-content:center}
  .cf-league__count{margin-left:0;text-align:center}
  .cf-league__grid{grid-template-columns:1fr}
  .calcio-hero__left{flex-direction:column;align-items:center;text-align:center}
  .calcio-badges{justify-content:center}
  .calcio-statbar{justify-content:center}
  .calcio-stat{min-width:70px}
  .calcio-tab{font-size:.78rem;padding:.7rem .8rem}
  .calcio-panel{padding:1rem}
  .cf-match__body{flex-direction:column;gap:.4rem}
  .cf-match__team{text-align:center!important}
  .cf-match__score{width:80px}
}
@media(max-width:420px){
  .calcio-stat__val{font-size:1.2rem}
  .cf-search__bar{padding:.12rem .12rem .12rem 1rem}
}

.calcio-row{display:flex;justify-content:space-between;align-items:center;gap:1rem}
.calcio-list{display:grid;gap:1rem}

.calcio-btn{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1rem;border-radius:999px;border:1px solid rgba(0,0,0,.12);text-decoration:none;font-weight:600}
.calcio-btn--ghost{background:transparent}
