  /* ===== THEME ===== */
:root{
  --brand-red:   #ed1f25;
  --brand-blue:  #253570;
  --brand-yellow:#f9ec17;

  --ink: #0b1220;
  --bg:  #f7f9fc;

  --glass: rgba(255,255,255,0.75);
  --glass-b: rgba(255,255,255,0.55);

  --radius: 20px;
  --shadow: 0 10px 30px rgba(0,0,0,.18);

  --field-blue-1: #0b1b3f;   /* deep navy */
  --field-blue-2: #133b8a;   /* rich blue */
  --field-red-1:  #6c0e12;   /* dark crimson */
  --field-red-2:  #b01418;   /* brandy red */

  --line: #fff;
  --lw: 3px;              /* line width */
  --rim: 1.8%;            /* inner margin around the field */
  --br: 1.2%;             /* corner radius of the field */

    /* UI */
  --shadow: 0 12px 30px rgba(0,0,0,.35);
  --border: rgba(255,255,255,.22);
  --muted: rgba(255,255,255,.75);
}

*{ box-sizing:border-box; }

.container{ margin-inline:auto; padding-inline: clamp(14px, 4vw, 24px); }

.section{ padding: clamp(28px, 6vw, 52px) 0; position: relative; }
.section-head{
  display:flex; align-items:end; justify-content:space-between; gap:12px; margin-bottom:14px;
}
.section-head h2{
  margin:0; color: #fff; letter-spacing:.2px;
  position: relative; padding-bottom: 6px;
}
.section-head h2::after{
  content:""; position:absolute; left:0; bottom:0; width:64px; height:4px;
  background: linear-gradient(90deg, var(--brand-red), transparent);
  border-radius: 2px;
}
.section-head.light h2{ color: #fff; }
.section-head.light h2::after{ background: linear-gradient(90deg, var(--brand-yellow), transparent); }

.btn{
  display:inline-flex; align-items:center; gap:8px; border:1px solid transparent;
  background: var(--brand-blue); color:#fff; padding:10px 14px; border-radius:12px;
  text-decoration:none; font-weight:700; box-shadow: 0 4px 14px rgba(37,53,112,.25);
  transition: transform .06s, filter .2s, box-shadow .2s, background .2s;
}
.btn:hover{ filter: brightness(1.05); box-shadow: 0 6px 20px rgba(37,53,112,.28); }
.btn:active{ transform: translateY(1px); }
.btn.secondary{ background: var(--field-red-1); color:#111;}
.btn.link{
  background: transparent; color: var(--brand-blue); border:1px solid rgba(37,53,112,.25);
  box-shadow: none;
}
.btn.link.white{ color: #fff; border-color: rgba(255,255,255,.5); }
.btn.pill{ border-radius: 999px; padding: 10px 16px; }


/* ===== Upcoming Matches Field ===== */

.section.field-wrap{ padding: clamp(18px, 3vh, 28px) 0px; }
.section-head{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  margin: 0 auto 12px auto; max-width: min(1200px, 100%); padding-inline: 4px;
}
.section-head h2{ margin:0; font-size: clamp(1.2rem, 1.3rem + .6vw, 1.8rem); }
.section-head .btn.link{ color:#fff; opacity:.85; text-decoration:none; }
.section-head .btn.link:hover{ opacity:1; text-decoration:underline; }

/* ===== FIELD FRAME (full field, goals LEFT/RIGHT) ===== */
.field-frame{
  position: relative;
  width: min(1200px, 100%);
  aspect-ratio: 105 / 68;
  margin: 0 auto;
  border-radius: 20px;
  overflow: hidden;
  border: 2px solid var(--line);
  box-shadow: var(--shadow), 0 0 0 3px rgba(237,31,37,.12) inset;
  color: #fff;
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,.065) 0 48px, rgba(0,0,0,.10) 48px 96px),
    radial-gradient(130% 130% at 80% 10%, rgba(0,0,0,.28), transparent 55%),
    linear-gradient(135deg, var(--field-blue-1) 0%, var(--field-blue-2) 33%, var(--field-red-1) 66%, var(--field-red-2) 100%);
  background-blend-mode: overlay, normal, normal;
}

/* Outer touchline */
.field-frame::before{
  content:""; position:absolute; inset: var(--rim);
  border: var(--lw) solid var(--line); border-radius: var(--br); pointer-events:none;
}

/* Halfway (vertical) + center circle + spot */
.field-frame::after{
  content:""; position:absolute; inset: var(--rim); pointer-events:none;
  background:
    linear-gradient(90deg, transparent calc(50% - calc(var(--lw)/2)), var(--line) calc(50% - calc(var(--lw)/2)) calc(50% + calc(var(--lw)/2)), transparent calc(50% + calc(var(--lw)/2))),
    radial-gradient(circle at 50% 50%, transparent 0 calc(13.46% - 1px), var(--line) calc(13.46% - 1px) calc(13.46% + 1px), transparent calc(13.46% + 1px)),
    radial-gradient(circle at 50% 50%, var(--line) 0 3px, transparent 4px);
  background-repeat:no-repeat; background-size:100% 100%;
}

/* ====== PENALTY AREAS (LEFT/RIGHT) ====== */
.field-frame .box{ position:absolute; top:50%; transform:translateY(-50%); height:59.29%; width:15.71%; border: var(--lw) solid var(--line); pointer-events:none; background:transparent; }
.field-frame .box.left{ left: var(--rim); border-left:0; border-radius: 0 .8% .8% 0; }
.field-frame .box.right{ right: var(--rim); border-right:0; border-radius: .8% 0 0 .8%; }

/* 6-yard boxes */
.field-frame .six{ position:absolute; top:50%; transform:translateY(-50%); height:26.94%; width:5.24%; border: var(--lw) solid var(--line); pointer-events:none; }
.field-frame .six.left{ left: calc(var(--rim) + 0px); border-left:0; border-radius: 0 .6% .6% 0; }
.field-frame .six.right{ right: calc(var(--rim) + 0px); border-right:0; border-radius: .6% 0 0 .6%; }

/* Goals */
.field-frame .goal{ position:absolute; top:50%; transform:translateY(-50%); height:10.76%; width:4.8%; border: var(--lw) solid var(--line); pointer-events:none; border-radius:.7%; }
.field-frame .goal.left{ left: calc(var(--rim) - var(--lw)); border-left:0; border-radius: 0 .7% .7% 0; }
.field-frame .goal.right{ right: calc(var(--rim) - var(--lw)); border-right:0; border-radius: .7% 0 0 .7%; }

/* Penalty spots + arcs */
.field-frame .box.left::after, .field-frame .box.right::after{
  content:""; position:absolute; top:50%; transform:translateY(-50%); width:6px; height:6px; border-radius:50%; background:var(--line);
}
.field-frame .box.left::after{ left: 10.48%; }
.field-frame .box.right::after{ right: 10.48%; }

.field-frame .box.left::before, .field-frame .box.right::before{
  content:""; position:absolute; top:50%; transform:translateY(-50%); width:26.92%; height:26.92%; border: var(--lw) solid transparent; border-radius:50%; pointer-events:none;
}
.field-frame .box.left::before{ left: calc(10.48% - 13.46%); border-right-color: var(--line); }
.field-frame .box.right::before{ right: calc(10.48% - 13.46%); border-left-color: var(--line); }

/* Corner arcs */
.field-frame .corner{
  position:absolute; width: 3%; height: 3%;
  border: var(--lw) solid transparent; border-radius:50%; pointer-events:none;
}
.field-frame .corner.tl{ left: var(--rim); top: var(--rim); border-right-color: var(--line); border-bottom-color: var(--line); }
.field-frame .corner.tr{ right: var(--rim); top: var(--rim); border-left-color: var(--line); border-bottom-color: var(--line); }
.field-frame .corner.bl{ left: var(--rim); bottom: var(--rim); border-right-color: var(--line); border-top-color: var(--line); }
.field-frame .corner.br{ right: var(--rim); bottom: var(--rim); border-left-color: var(--line); border-top-color: var(--line); }

/* =========================================================
   MATCH OVERLAY: next 3 stacked
   ========================================================= */
.match-overlay{
  position:absolute; inset: clamp(10px, var(--rim), 24px);
  display:flex; align-items:center; justify-content:center;
  z-index:3; pointer-events:none;  /* purely display */
}

.match-stack{
  display:flex; flex-direction:column; gap: clamp(10px, 1.8vw, 16px);
  width: min(92%, 980px);
}

/* one match card */
.match-card{
  display:grid; grid-template-rows: auto auto auto; align-items:center; justify-items:center;
  padding: clamp(8px, 1.6vw, 14px) clamp(10px, 2vw, 18px);
  border-radius: 16px;
  background: rgba(8,12,26,.48);
  border: 1px solid var(--border);
  backdrop-filter: blur(6px);
  box-shadow: 0 6px 18px rgba(0,0,0,.3);
}

/* meta rows (top/bottom) */
.match-meta{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; opacity:.95; }
.match-meta .dot{ opacity:.6; }

/* duel row */
.duel{
  display:grid; grid-template-columns: 1fr auto 1fr; align-items:center; gap: clamp(12px, 2vw, 24px);
  width: 100%;
}
.duel .side{
  display: grid;
  grid-template-columns: auto minmax(0,1fr) auto; /* crest | name | badge */
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.duel .side.right{
  direction: rtl;                 /* mirror on the right */
}
.duel .side.right > *{
  direction: ltr;                 /* keep text normal */
}

.crest{
  width: clamp(30px, 3.8vw, 42px);
  height: clamp(30px, 3.8vw, 42px);
  border-radius: 50%;
  border: 2px solid var(--admin-border-2, rgba(255,255,255,.25));
  background: linear-gradient(135deg, rgba(var(--blue-rgb, 37,53,112), .20), rgba(var(--blue-dark-rgb, 27,42,89), .35));
  display: grid;
  place-items: center;
  overflow: hidden;
}
.crest img{
  width: 100%;
  height: 100%;
  object-fit: contain;            /* handles GIF/SVG/PNG nicely */
  display: block;
}
.crest__init{
  font-weight: 800;
  font-size: clamp(10px, 1.6vw, 12px);
  color: var(--gold);
  letter-spacing: .04em;
}




/* tighter name so logos fit */
.duel .name{
  font-weight: 800;
  font-size: clamp(1.05rem, 0.55rem + 2.4vw, 1.7rem); /* was bigger; made smaller */
  letter-spacing: .2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: clamp(120px, 32vw, 360px);
}
.duel .badge{ display:inline-flex; align-items:center; padding:4px 10px; border-radius:999px; font-weight:800; font-size:.78rem; letter-spacing:.25px; white-space: nowrap;}
.duel .badge.home{ background: rgba(249,236,23,.95); color:#111; }
.duel .badge.away{ background: rgba(237,31,37,.95); color:#fff; }
.duel .vs{ font-weight:900; font-size: clamp(1.2rem, .8rem + 2vw, 1.8rem); opacity:.9; padding:2px 10px; border:1px solid var(--border); border-radius:999px; line-height:1; }

.duel .side.left .name,
.duel .side.right .name{
  max-width: clamp(120px, 32vw, 400px);
}

.loc{ color: var(--muted); }
.meta-strong{ font-weight:700; }

/* Highlight first (next) match */
.match-card.next{
  background: rgba(8, 12, 26, 0.26);
  border-color: rgba(255,255,255,.35);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.12), 0 10px 24px rgba(0,0,0,.35);
}

/* Mobile */
@media (max-width: 720px){

  /* 1) Give the field more vertical space on mobile */
  .field-frame{
    aspect-ratio: auto;              /* let height be independent of width */
    height: min(50vh, 680px);        /* make it taller; tweak 80vh/680px as needed */
    min-height: 320px;               /* safety floor */
  }

  /* 2) Overlay insets a bit tighter so content fits comfortably */
  .match-overlay{
    inset: 10px;                     /* was rim-based; tighter margins on phones */
  }

  /* 3) Stack side content (badge above name) – already doing this,
        but now give the name MAX room and allow 2 lines. */
  .duel{ grid-template-columns: 1fr; text-align:center; gap: 8px; }
  .duel .side, .duel .side.right{
    grid-template-columns: auto 1fr;   /* crest | name; badge stacks above via order */
    direction: ltr;
    justify-items: center;
  }
  .duel .badge{ order: -1; }           /* badge above on mobile */
  .duel .name{
    white-space: normal;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    line-clamp: 2;
    font-size: clamp(1rem, 0.85rem + 2vw, 1.35rem);
    max-width: 100%;
  }
  /* 4) Let names wrap to TWO lines (then ellipsis) */
  .duel .name{
    max-width: 100%;
    width: 100%;
    margin: 0;
    padding: 0;
    overflow: hidden;
    white-space: normal;             /* allow wrapping */
    display: -webkit-box;            /* line-clamp technique */
    -webkit-line-clamp: 2;           /* show up to 2 lines */
    -webkit-box-orient: vertical;
    line-clamp: 2;                   /* (future-compatible) */
  }

  /* 5) Slightly smaller typography + tighter card padding to free space */
  .match-card{
    padding: 10px 10px;
  }
  .duel .vs{
    margin: 4px 0;
    font-size: clamp(1rem, 0.8rem + 2vw, 1.2rem);
    padding: 2px 8px;
  }

  /* 6) Only display the first (next) match on mobile (as you asked earlier) */
  .match-stack .match-card{ display: none; }
  .match-stack .match-card:nth-child(1){ display: grid; }
}

/* ===== NEWS GRID ===== */
.news-grid{
    display:grid;
  align-items: stretch;                /* grid items fill row height */
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: clamp(14px, 2vw, 20px);


}

/* ===== CARD (flush edges: NO left/right/bottom padding) ===== */
.news-card{
  display:flex; flex-direction:column;
  border-radius:18px; overflow:hidden;
  /* theme gradient background on the card itself */
  background:
    radial-gradient(900px 420px at 12% -10%,
      color-mix(in oklab, var(--field-red-2) 32%, transparent) 0%, transparent 65%),
    radial-gradient(800px 380px at 110% 40%,
      color-mix(in oklab, var(--field-red-1) 24%, transparent) 0%, transparent 70%),
    linear-gradient(135deg, var(--field-blue-1) 0%, var(--field-blue-2) 100%);
  /* no inner padding; edges are flush */
  padding: 0;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
  transition: transform .12s ease, box-shadow .2s ease;
  height: 100%;
}
.news-card:hover{ transform: translateY(-2px); box-shadow: 0 12px 28px rgba(0,0,0,.12); }

/* ===== TITLE (top, large, obvious) ===== */
.news-title{
  margin: clamp(10px, 1.6vw, 14px) 0 8px;  /* top-only spacing; no L/R/B */
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: .2px;
  color: #fff;
  text-wrap: balance;
  text-shadow: 0 1px 0 rgba(0,0,0,.25);
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: clamp(22px, 1.2vw, 12px);
}
.news-title a{
  text-decoration: none;
  color: #fff;
}
.news-title a:hover{ opacity: .95; }
.news-title::after{
  content:"";
  display:block;
  height: 3px;
  width: 56px;
  margin-top: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--field-red-2), var(--field-red-1));
}

/* ===== IMAGE (edge-to-edge) + OVERLAY SUMMARY ===== */
.news-media{
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  /* flush edges: NO L/R/B margin; just sits under the title */
  margin: 0;
  border-radius: 0;
  isolation: isolate;
  color: #000;
}
.news-media img{
  width:100%; height:100%; object-fit:cover; display:block;
  transition: transform .4s ease;
}
.news-card:hover .news-media img{ transform: scale(1.03); }


/* summary overlay (sits on image) */
.news-summary{
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;     /* clamp with ellipses */
  -webkit-box-orient: vertical;
  overflow: hidden;
  color: #000;
}

/* ===== GLASS CTA (below image, flush L/R/B) ===== */
.news-glass{
  margin: 0;                           /* remove top gap so it hugs the image */
  flex: 1 1 auto;                      /* <-- grow to fill the remaining space */
  display: flex;                       /* layout for summary + CTA */
  flex-direction: column;
  padding: 12px;                       /* internal padding for readability */
  border-radius: 0 0 18px 18px;        /* match card bottom corners */
  border-top: 1px solid color-mix(in oklab, var(--field-blue-1) 18%, #fff);
  border-left: 0; border-right: 0; border-bottom: 0;
  background: linear-gradient(
    180deg,
    color-mix(in oklab, #ffffff 70%, transparent),
    color-mix(in oklab, #ffffff 40%, transparent)
  );
  backdrop-filter: blur(6px) saturate(120%);
  -webkit-backdrop-filter: blur(6px) saturate(120%);
    color: #000;

}

.news-btn-cta{
  display:inline-block;
  padding: 10px 16px;
  border-radius: 999px;
  font-weight: 800;
  font-size: .95rem;
  color:#fff; text-decoration:none;
  background: linear-gradient(180deg, var(--field-red-2), var(--field-red-1));
  box-shadow: 0 8px 20px rgba(176,20,24,.28);
  transition: transform .12s ease, filter .2s ease;
}
.news-btn-cta:hover{ transform: translateY(-1px); filter: brightness(1.05); }
.cta-end { justify-content: end; align-items: end; text-align: end; }
/* ===== Responsive ===== */
@media (max-width: 640px){
  .news-grid{ grid-template-columns: 1fr 1fr; gap: 12px; }
  .news-title{ margin-top: 10px; font-size: clamp(1.35rem, 1.05rem + 1vw, 1.6rem); }
  .news-summary{ -webkit-line-clamp: 2; }
  .news-title{ font-size: 12px; }

}

@media (max-width: 640px){
  .news-grid{ 
    grid-template-columns: 1fr; 
    gap: 12px; 
  }
}

/* ===== SHOP ===== */
/* ===== Shop 3D Coverflow (scoped) ===== */
#shop.shop-3d { position: relative; }
#shop.shop-3d .shop3d-wrap { position: relative; padding: 2.2rem 0; }
#shop.shop-3d .shop3d-bg{
  position:absolute; inset:0; z-index:0; opacity:.6; pointer-events:none;
  background:
    linear-gradient(180deg, rgba(3,77,126,.06), rgba(3,77,126,0));
}

/* Swiper sizing */
#shop.shop-3d .swiper.shop3d-swiper{
  position:relative; z-index:1;
  width:min(1100px,92%); margin-inline:auto;
  padding: clamp(10px, 2vw, 18px) 0 clamp(28px, 3vw, 44px);
}

#shop.shop-3d .swiper-wrapper{ align-items: center; }

/* Each slide auto-sizes like a card */
#shop.shop-3d .swiper-slide{
  width: clamp(220px, 28vw, 320px);
  display:flex; align-items:stretch; justify-content:center;
}

/* Card */
#shop.shop-3d .shop3d-card{
  --lift: 0;
  position:relative; display:block; width:100%; border-radius:18px; overflow:hidden;
  border:1px solid rgba(255,255,255,.18);
  background: #ffffff url('/assets/bg/grass.png') center/cover no-repeat;
  box-shadow: 0 calc(18px + var(--lift)) calc(40px + var(--lift)) rgba(0,0,0,.35);
  transform: translateZ(0) scale(0.94) rotateY(0deg);
  transition: transform .45s ease, box-shadow .35s ease, border-color .35s ease, filter .35s ease;
}

/* Transparent PNG stage */
#shop.shop-3d .shop3d-art{
  display:grid; place-items:center;
  padding: 0 !important; 
}
#shop.shop-3d .shop3d-art img{
  width: 100%; height: 100%; object-fit: contain; object-position: bottom;
  filter: drop-shadow(0 14px 34px rgba(0,0,0,.45));
}
#shop.shop-3d .shop3d-card.cover .shop3d-art img{
  object-fit: cover;
}
/* Meta */
#shop.shop-3d .shop3d-meta{
  background: #0b1b3f;
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding: 10px 12px 12px; color:#fff;
}
#shop.shop-3d .shop3d-meta .name{ font-weight:800; letter-spacing:.2px; }
#shop.shop-3d .shop3d-meta .price{
  padding:6px 10px; border-radius:999px;
  background: color-mix(in oklab, var(--glass) 90%, transparent);
  border: 1px solid rgba(255,255,255,.28); font-weight:800;
}

/* Coverflow effect emphasis */
#shop.shop-3d .swiper-slide .shop3d-card{
  transform: translateZ(-160px) rotateY(var(--tilt, 0deg)) scale(0.92);
  filter: saturate(.92) brightness(.95);
}
#shop.shop-3d .swiper-slide-active .shop3d-card{
  --lift: 6px;
  transform: translateZ(0) rotateY(0deg) scale(1.06);
  border-color: color-mix(in oklab, var(--gold) 40%, white);
  filter: saturate(1.05) brightness(1.03);
}
#shop.shop-3d .swiper-slide-prev .shop3d-card{ --tilt: 18deg; }
#shop.shop-3d .swiper-slide-next .shop3d-card{ --tilt: -18deg; }

/* Controls & pagination */

#shop.shop-3d .swiper-pagination-bullet{
  background: rgba(255,255,255,.6);
}
#shop.shop-3d .swiper-pagination-bullet-active{
  background: var(--gold);
}

/* Empty state */
#shop.shop-3d .shop3d-empty{
  display:grid; place-items:center; width:100%; min-height:240px;
  color:#fff; opacity:.65; border:1px dashed rgba(255,255,255,.25); border-radius:12px;
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  #shop.shop-3d .swiper-slide .shop3d-card{ transform:none !important; }
}

#shop.shop-3d .swiper-button-prev,
#shop.shop-3d .swiper-button-next{
  width: 46px;
  height: 46px;
  border-radius: 999px;
  background: (255,255,255,0.25);
  backdrop-filter: blur(8px);
  box-shadow: 0 12px 30px rgba(0,0,0,.35);;
  top: 50%; transform: translateY(-50%);  /* center vertically */
}

/* place them a bit farther from the edges; tweak to taste */
#shop.shop-3d .swiper-button-prev { left: clamp(8px, 2vw, 18px); }
#shop.shop-3d .swiper-button-next { right: clamp(8px, 2vw, 18px); }

/* Remove underline on the card link + states (scoped to the shop) */
#shop.shop-3d .shop3d-card,
#shop.shop-3d .shop3d-card:hover,
#shop.shop-3d .shop3d-card:focus,
#shop.shop-3d .shop3d-card:active{
  text-decoration: none !important;
}

/* Extra guard in case a theme adds borders/underlines to child text */
#shop.shop-3d .shop3d-card .name,
#shop.shop-3d .shop3d-card .price{
  text-decoration: none !important;
  border-bottom: 0 !important;
}

/* Keep keyboard focus visible */
#shop.shop-3d .shop3d-card:focus-visible{
  outline: 3px solid var(--gold);
  outline-offset: 3px;
}


/* ===== TEAMS QUICK ===== */
/* ===== TEAMS QUICK — larger cards with visible labels (scoped) ===== */
.teams-quick .grid-2x2{
  display: grid;
  grid-template-columns: repeat(2, minmax(480px, 1fr)); /* bigger columns */
  gap: clamp(16px, 2.2vw, 32px);
}

@media (max-width: 900px){
  .teams-quick .grid-2x2{ grid-template-columns: 1fr; }
}

.teams-quick .tile{
  position: relative;
  display: block;
  color: #fff;
  text-decoration: none;
  border-radius: 22px;
  overflow: hidden;
  box-shadow: 0 16px 34px rgba(0,0,0,.28);
  isolation: isolate; /* creates a stacking context for reliable z-index */
}

/* Larger media height */
.teams-quick .tile img{
  width: 100%;
  height: clamp(320px, 40vw, 560px); /* bigger than before */
  object-fit: cover;
  display: block;
  filter: saturate(1.06);
}

/* Subtle gradient to improve legibility */
.teams-quick .tile::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.38) 100%);
  pointer-events: none;
  z-index: 1; /* sits above the image but below the label */
}

/* Bold label */
.teams-quick .tile span{
  position: absolute;
  left: clamp(12px, 1.6vw, 20px);
  bottom: clamp(12px, 1.6vw, 20px);
  padding: 10px 16px;
  border-radius: 12px;
  font-weight: 900;
  font-size: clamp(14px, 1.3vw, 18px);
  letter-spacing: .3px;
  color: #fff;
  background: rgba(0,0,0,.55);
  border: 1px solid rgba(255,255,255,.55);
  z-index: 2; /* ensure above overlay */
  text-decoration: none !important;
  border-bottom: 0 !important;
}

/* Focus style for accessibility */
.teams-quick .tile:focus-visible span{
  outline: 3px solid var(--gold, #f9ec17);
  outline-offset: 3px;
}


/* ===== STATS (simple, bold KPIs) ===== */
.kpi-grid{
  display:grid; grid-template-columns: repeat(auto-fit,minmax(160px,1fr)); gap: 14px;
}
.kpi{
  background:#fff; border:1px solid #e7eef7; border-radius: 16px; padding: 16px;
  box-shadow: 0 6px 18px rgba(0,0,0,.06); text-align:center;
}
.kpi-num{
  font-size: clamp(1.6rem, 4.6vw, 2.2rem); font-weight: 900; color: var(--brand-blue);
  text-shadow: 0 1px 0 #fff, 0 8px 24px rgba(37,53,112,.12);
}
.kpi-label{ color:#456a86; }

/* ===== PARTNERS ===== */
/* Sponsors grid */
.partners .sponsor-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: clamp(12px, 1.6vw, 20px);
  align-items: stretch;
}

/* Logo card */
.partners .logo-card{
  position: relative;
  display: block;
  border-radius: 16px;
  padding: 0;
  aspect-ratio: 1 / 1;                   /* neat, consistent tiles */
  background: #fff;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 10px 26px rgba(0,0,0,.18);
  transform-style: preserve-3d;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  will-change: transform;
  overflow: hidden;
}

/* Center the logo; PNGs with transparency sit on soft white */
.partners .logo-wrap{
  position: absolute; inset: 0;
  display: grid; place-items: center;
  padding: clamp(5px, 2.2vw, 10px);
}
.partners .logo-card img{
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display: block;
  transform: translateZ(24px) scale(.98);
  transition: transform .25s ease;
  border-radius: 10px;

}

/* 3D lift on hover/focus (no JS needed) */
.partners .logo-card:hover,
.partners .logo-card:focus-visible{
  transform: translateY(-6px) rotateX(6deg) rotateY(-6deg);
  box-shadow: 0 18px 44px rgba(0,0,0,.26);
  border-color: rgba(0,0,0,.10);
}
.partners .logo-card:hover img,
.partners .logo-card:focus-visible img{
  transform: translateZ(40px) scale(1);
}

/* Keyboard focus */
.partners .logo-card:focus-visible{
  outline: 3px solid var(--gold, #f9ec17);
  outline-offset: 2px;
}


/* Make Gold tiles 2×2 */
.logo-card--gold{
  grid-column: span 2;
  grid-row: span 2;
}

/* Compact tweaks for small screens */
@media (max-width: 520px){
  .partners .sponsor-grid{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 5px; }
  .partners .logo-card{ border-radius: 14px; }
}

/* Utility */
.card{ background:#fff; border:1px solid #e7eef7; border-radius:16px; padding: 12px; }
.muted{ color:#5a7a90; }


/* LANDING HEADER */

/* ===== FC Glattal Dübendorf – HERO (scoped) ===== */
.fcgd-hero.hero{
  position:relative; min-height:clamp(520px,70vh,880px);
  display:grid; grid-template-rows:auto 1fr; overflow:clip; isolation:isolate;
  color:#fff;
  background:linear-gradient(120deg,var(--blue-dark) 0%,var(--blue-mid) 40%,var(--red) 115%);
  --hero-gutter: clamp(24px, 6vw, 120px); /* default */
  margin-top: -10vh;
  padding-top: 15vh;
  padding-bottom: 5vh;
}

/* apply only to the horizontal sides */
.fcgd-hero .nav,
.fcgd-hero .hero-content {
  padding-inline: var(--hero-gutter) !important;
}

/* step up on wider and ultra-wide screens */
@media (min-width: 1440px) {
  .fcgd-hero { --hero-gutter: clamp(48px, 8vw, 160px); }
}
@media (min-width: 1920px) {
  .fcgd-hero { --hero-gutter: clamp(72px, 10vw, 220px); }
}

/* Optional: softly cap the line length while keeping full-bleed background */
@media (min-width: 1280px) {
  .fcgd-hero .nav,
  .fcgd-hero .hero-content {
    max-width: 1480px;        /* adjust to taste */
    margin-inline: auto;      /* center inside the full-width header */
  }
}
.fcgd-hero.hero::before{
  content:""; position:absolute; inset:-20% -20% auto -20%; height:120%; z-index:0; pointer-events:none;
  background:
    radial-gradient(1200px 500px at 80% 20%, color-mix(in oklab,var(--gold) 55%,transparent) 0%, transparent 60%),
    conic-gradient(from 210deg at 70% 20%, color-mix(in oklab,var(--red) 38%,transparent) 0 25%, transparent 25% 55%, color-mix(in oklab,var(--blue) 40%,transparent) 55% 70%, transparent 70% 100%);
  mix-blend-mode:screen; opacity:.85; transform:translate3d(0,0,0);
  animation: fcgd-beam 12s ease-in-out infinite alternate;
}
@keyframes fcgd-beam{from{transform:translateY(-6%) rotate(-1deg)}to{transform:translateY(6%) rotate(1deg)}}

/* Background effects + subtle SVG tile */
.fcgd-hero .abstract-bg{position:absolute; inset:0; z-index:0; overflow:hidden;}
.fcgd-hero .abstract-bg::before{
  content:""; position:absolute; inset:-20%; filter:blur(12px); opacity:.9; pointer-events:none;
  background:
    radial-gradient(900px 480px at 15% 20%, color-mix(in oklab,var(--red) 50%,transparent) 0%, transparent 60%),
    radial-gradient(700px 420px at 85% 15%, color-mix(in oklab,var(--gold) 55%,transparent) 0%, transparent 65%),
    radial-gradient(900px 540px at 70% 85%, color-mix(in oklab,var(--blue) 55%,transparent) 0%, transparent 60%),
    conic-gradient(from 220deg at 60% 30%, rgba(255,255,255,.08), transparent 40%, rgba(255,255,255,.08) 60%, transparent 90%);
  mix-blend-mode:screen; animation: fcgd-float-bg 18s ease-in-out infinite alternate;
}
@keyframes fcgd-float-bg{from{transform:translateY(-3%) rotate(-.6deg)}to{transform:translateY(3%) rotate(.6deg)}}
.fcgd-hero .logo-pattern{position:absolute; inset:-2% -2% -2% -2%; opacity:.07; mix-blend-mode:overlay; pointer-events:none;}
.fcgd-hero .grain{position:absolute; inset:-2px; background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><filter id="n"><feTurbulence type="fractalNoise" baseFrequency="0.9" numOctaves="2" stitchTiles="stitch"/><feColorMatrix type="saturate" values="0"/><feComponentTransfer><feFuncA type="linear" slope="0.05"/></feComponentTransfer></filter><rect width="100%" height="100%" filter="url(%23n)"/></svg>'); opacity:.35; mix-blend-mode:overlay}

/* NAV */
/* ===== Title-only navbar (scoped) ===== */
.fcgd-hero .nav.nav-title-only{
  justify-content: center;               /* center the title */
  padding-block: clamp(10px, 2vw, 20px);
  padding-inline: var(--hero-gutter, clamp(16px, 6vw, 120px));
}

.fcgd-hero .brand-title{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;

  /* Typography */
  text-transform: uppercase;
  letter-spacing: .18em;
  font-weight: 1000;
  font-size: clamp(18px, 2.2vw, 30px);
  line-height: 1;

  /* High contrast + subtle glass */
  color: #fff;
  padding: 12px 20px;
  border-radius: 16px;
  background: color-mix(in oklab,var(--red) 14%, rgba(255,255,255,.08));
  backdrop-filter:blur(8px);
  border: 1px solid rgba(255,255,255,.22);
  box-shadow: var(--shadow);
  backdrop-filter: blur(8px);

  /* Glow for bold, premium feel */
  text-shadow:
    0 1px 0 rgba(0,0,0,.35),
    0 6px 16px rgba(0,0,0,.35),
    0 0 18px color-mix(in oklab, var(--gold) 25%, transparent);
}


/* Sticky state still looks nice on scroll */
.fcgd-hero .nav.is-stuck{
  position: sticky; top: 0;
  backdrop-filter: blur(10px);
  background: color-mix(in oklab, var(--blue-dark) 68%, transparent);
  box-shadow: 0 6px 24px rgba(0,0,0,.25);
  border-bottom: 1px solid rgba(255,255,255,.12);
}

/* Wider screens: add breathing room + optional max width */
@media (min-width: 1440px){
  .fcgd-hero .nav.nav-title-only{ padding-inline: clamp(48px, 8vw, 160px); }
}
@media (min-width: 1280px){
  .fcgd-hero .nav.nav-title-only{
    max-width: 1480px;
    margin-inline: auto;
  }
}


/* Buttons (scoped + high contrast) */
.fcgd-hero .btn{appearance:none; border:0; cursor:pointer; text-decoration:none; font-weight:800;
  padding:14px 20px; border-radius:999px; display:inline-flex; align-items:center; gap:10px; position:relative; overflow:hidden;
  transform:translateZ(0); transition:transform .12s ease, box-shadow .2s ease; color:var(--ink) !important}
.fcgd-hero .btn:focus-visible{outline:3px solid var(--gold); outline-offset:2px}
.fcgd-hero .btn .shine{position:absolute; inset:-200% -40%; background:linear-gradient(120deg,transparent 20%, rgba(255,255,255,.9) 50%, transparent 80%); transform:translateX(-60%)}
.fcgd-hero .btn:hover .shine{animation:fcgd-shine 1.2s ease forwards}
@keyframes fcgd-shine{to{transform:translateX(120%)}}
.fcgd-hero .btn-primary{background:linear-gradient(180deg,var(--gold) 0%, var(--gold-light) 85%) !important; color:#1a1400 !important; border:2px solid color-mix(in oklab,var(--gold) 35%, black) !important; box-shadow:var(--shadow)}
.fcgd-hero .btn-secondary{background:#fff !important; color:var(--blue-dark) !important; border:2px solid rgba(0,0,0,.06) !important; box-shadow:var(--shadow)}
.fcgd-hero .btn-ghost{background:color-mix(in oklab,var(--blue-dark) 32%, rgba(255,255,255,.12)) !important; color:#fff !important; border:2px solid rgba(255,255,255,.45) !important; box-shadow:var(--shadow)}
.fcgd-hero .btn:hover{transform:translateY(-2px); box-shadow:0 16px 36px rgba(0,0,0,.35)}
.fcgd-hero .btn:active{transform:translateY(0); box-shadow:0 8px 20px rgba(0,0,0,.35)}

/* Content */
.fcgd-hero .hero-content{position:relative; z-index:1; display:grid; grid-template-columns:1.1fr .9fr;
  gap:clamp(24px,4vw,56px); align-items:center; padding:0 clamp(16px,4vw,48px) clamp(28px,4vw,56px)}
.fcgd-hero .copy{max-width:780px}
.fcgd-hero .eyebrow{display:inline-flex; gap:8px; align-items:center; margin-bottom:12px; font-weight:800; letter-spacing:.4px}
.fcgd-hero .eyebrow .tag{padding:6px 10px; border-radius:999px; border:1.6px solid rgba(255,255,255,.45);
  background:color-mix(in oklab,var(--red) 14%, rgba(255,255,255,.08)); backdrop-filter:blur(8px)}
.fcgd-hero h1{margin:0 0 10px; font-size:clamp(34px,6.4vw,72px); line-height:1.02; letter-spacing:-.5px; text-wrap:balance}
.fcgd-hero .lead{margin:0 0 24px; font-size:clamp(16px,1.6vw,20px); color:var(--muted); max-width:65ch}



/* Responsive tweaks */
@media (max-width:980px){
  .fcgd-hero .hero-content{grid-template-columns:1fr}
  .fcgd-hero .interactive{order:-1}
}
@media (max-width:640px){
  .fcgd-hero .brand-name{font-size:18px}
  .fcgd-hero h1{font-size:clamp(28px,9.5vw,48px)}
  .fcgd-hero .nav-title-only {
    justify-content: center; align-items: center; text-align: center;
  }
}

#heroFlip .bg{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit: cover; object-position: center; z-index:0; pointer-events:none;
}




/* ===== INTERACTIVE PANE (Video container) ===== */
.interactive.hero-video{
  position: relative;
  border-radius: 16px;
  overflow: hidden;          /* <-- keeps video + overlays clipped to pane */
  isolate: isolate;          /* prevent external stacking-context issues */
  background: #0b1220;       /* fallback while video loads */
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
  
  /* Responsive height; pick one of the two approaches below: */
  aspect-ratio: 16 / 9;      /* modern browsers */
  /* Or, if you prefer fixed-height feel: */
  /* min-height: 220px; height: clamp(220px, 36vw, 420px); */
}

/* Background image sits behind video as a graceful fallback */
.interactive.hero-video .bg{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

/* The video itself – fully contained in the pane */
.interactive.hero-video video{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;          /* fills pane without stretching */
  z-index: 1;
}

/* Overlays (orbs/logo) go above the video */
.interactive.hero-video .orbs,
.interactive.hero-video .logo-big{
  position: absolute;
  z-index: 2;
  pointer-events: none;       /* let clicks reach the video/mute button */
}

/* Mute button on top and always clickable */
.interactive.hero-video .mute{
  position: absolute;
  right: 12px;
  bottom: 12px;
  z-index: 3;
  border: 0;
  border-radius: 999px;
  padding: 8px 12px;
  background: rgba(0,0,0,.5);
  color: #fff;
  backdrop-filter: blur(4px);
  font: inherit;
  cursor: pointer;
}
.interactive.hero-video .mute .on{ display: none; }
.interactive.hero-video .mute.is-on .on{ display: inline; }
.interactive.hero-video .mute.is-on .off{ display: none; }

/* Optional: tweak for small screens */
@media (max-width: 600px){
  .interactive.hero-video{
    border-radius: 12px;
    /* aspect-ratio: 4 / 3;  // uncomment if you prefer a taller pane on mobile */
  }
}












/* =======================================================================
   HERO PITCH — FLAT, REAL FIELD PNG, AUTO DEPTH SCALE
   Mobile: hide field; 2×3 grid of 6 cards
   ======================================================================= */

  .hero-pitch{
    --pitch-max-w: 1600px;                  /* max pixel width of the field */
    --card-w: 120px;/*clamp(90px, 20vw, 180px);*/
    --card-h: calc(var(--card-w) * 1.5);
    --radius: 18px;

    --pitch-pos: 50% 50%;
    --pitch-w: 16.4; 
    --pitch-h: 12;
    --pitch-padY: clamp(100px, 4vw, 200px);
      /* Mobile grid spacing */
    --grid-gap: 14px;
    overflow: visible !important; /* was: hidden */
    --card-ratio: 2 / 3;                    /* flip-card aspect ratio */
  }

  /* Desktop/tablet field */
  .hero-pitch .pitch{
    padding-top: 100px;
    position: relative;
    width: min(100%, var(--pitch-max-w));   /* no overflow, centers correctly */
    margin-inline: auto;                 /* centers it */
    line-height: 0;                          /* remove inline image gap */
    filter: drop-shadow(0 24px 60px rgba(0,0,0,.35));       /* extra space */
  }

  .pitch-img{
    display:block; width:100%; height:auto; border-radius: 14px;
    user-select:none; -webkit-user-drag:none;
  }
  .pitch-inner{
    position:absolute; inset:0; border-radius:14px; overflow:visible;
  }

/* Absolute placement on field (relative to .pitch-inner) */
.hero-pitch .player-node{
  position:absolute;
  left: calc(var(--x) * 1%);
  top:  calc(var(--y) * 1%);
  transform: translate(-50%, -50%);
  z-index: var(--z, 1);
}

/* Scale by depth (y) on desktop */
.hero-pitch .player-node .card-wrap{
  width: var(--card-w);
  aspect-ratio: var(--card-ratio);
  transform: scale(var(--scale, 1));
  transform-origin: center bottom;
}

.hero-pitch .player-node .flip-card{ width: var(--card-w); height: var(--card-h); }

/* Flip mechanics */
.hero-pitch .flip-card .inner{
  position: relative; width: 100%; height: 100%;
  transform-style: preserve-3d;
  transition: transform .6s cubic-bezier(.2,.85,.2,1);
}
.hero-pitch .flip-card:hover .inner,
.hero-pitch .flip-card.is-flipped .inner{ transform: rotateY(180deg); }
.hero-pitch .flip-face{
  position:absolute; inset:0; backface-visibility:hidden;
  border-radius: var(--radius); overflow:hidden;
}
.hero-pitch .flip-face.flip-back{ transform: rotateY(180deg); }
.hero-pitch .player-card{
  position:relative;
  width:100%; height:100%;
  border-radius:var(--radius);
  overflow:visible; background:var(--white);
  color:var(--text); box-shadow: var(--shadow-soft);
  display:grid; grid-template-rows: 1fr auto; isolation:isolate;
  transition: transform .35s ease, box-shadow .35s ease, filter .35s ease;
  border:1px solid rgba(255,255,255,.06);
}

.hero-pitch .ink{
  position:absolute; inset:0; z-index:1;
  background: linear-gradient(180deg, rgba(10,12,22,.60) 0%, rgba(10,12,22,.22) 35%, rgba(10,12,22,0) 55%);
  pointer-events:none;
}
/* Player image */

.player-img.player-img--lg{
  position:absolute; z-index:2;
  bottom:-6px; left:50%; transform:translateX(-50%);
  width: 102%; /* was ~82% — make the player dominate */
  max-width: 105%;
  height:auto;
  filter: drop-shadow(0 18px 40px rgba(0,0,0,.55));
  pointer-events:none;
}
/* Jersey number: bigger, front right / back left */
.jersey{
  position:absolute; z-index:3; top:10px;
  font-weight:1000; line-height:1;
  font-size: clamp(18px, 2vw, 24px);
  padding: 6px 12px;
  border-radius: 14px;
  color:#fff;
  background: rgba(255,255,255,.1);
  border:1px solid rgba(0,0,0,.08);
  box-shadow: 0 12px 26px rgba(0,0,0,.28);
}
.jersey--front{ right: 12px; text-align:right; }
.jersey--back{  left:  12px; text-align:left;  }

/* Content overlay (no blur – keeps PNG crisp) */
.hero-pitch  .info{
  background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.06) 100%);
  backdrop-filter: none; -webkit-backdrop-filter: none;
}

/* Front name/position unchanged, but tighten spacing for larger art */
.player-card .info{ padding: var(--pad); padding-top: 8px; }


.hero-pitch  .badge{
  position:absolute; top:12px; right:12px; z-index:3;
  font-size:12px; letter-spacing:.4px; text-transform:uppercase;
  padding:6px 10px; border-radius:999px; background:rgba(0,0,0,.55); color:#fff;
}
.hero-pitch .name{
  margin:0 0 2px 0; font-size:12px; font-weight:800; letter-spacing:.2px;
  color:#fff; text-shadow: 0 1px 0 rgba(0,0,0,.25);
}
.hero-pitch .position{
  margin:0 0 10px 0; font-size:8px; color:#d1d5db; text-transform:uppercase; letter-spacing:.6px;
}

/* Optional lift on hover */
.hero-pitch .player-node .player-card:hover{ transform: translateY(-8px); }

/* ---------------- Mobile (≤680px): no field, 2×3 grid, show 6 cards ---------------- */
@media (max-width: 1200px){
  /* card base size on mobile */
  .hero-pitch{ --card-w: clamp(140px, 44vw, 190px); overflow: visible; } /* was: hidden */

  .hero-pitch .pitch{
    width: 100%;
    padding: 0;
    aspect-ratio: auto;
    background: none;
    box-shadow: none;
    margin: 0 auto;
  }

  .hero-pitch .pitch-inner{
    position: static;
    background: none;
    border-radius: 0;

    /* 2-col grid that actually fits */
    box-sizing: border-box;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--grid-gap, 14px);
    padding: 8px 10px; /* small gutters to avoid edge clipping */
  }

  /* Grid items must be allowed to shrink */
  .hero-pitch .player-node{
    position: static;
    transform: none;
    z-index: auto;
    min-width: 0;  /* <— critical on iOS */
  }

  /* Cards fill their cell and never overflow it */
  .hero-pitch .player-node .flip-card{
    width: 100%;
    max-width: 100%;
    min-width: 0;          /* <— critical */
    height: auto;
    aspect-ratio: 2 / 3;
    touch-action: manipulation;
  }

  /* No depth scaling in grid */
  .hero-pitch .player-node .card-wrap{ transform: none; }

  /* Prevent content (long names/badges) from pushing width */
  .hero-pitch .player-card{ overflow: hidden; }
  .hero-pitch .info{ min-width: 0; }
  .hero-pitch .name{
    font-size: 18px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;  /* trim very long names */
  }
  .hero-pitch .position{ font-size: 11px; }
  .pitch-img {display: none;}
}




/* Stats grid */
.stats{
  display:grid; grid-template-columns: repeat(2, 2fr); gap:8px;
}
.stat{
  display:grid; gap:4px; text-align:center;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  padding:10px; border-radius:12px;
}
.stat span{ font-size:11px; color:#cbd5e1; text-transform:uppercase; letter-spacing:.5px }
.stat strong{ font-size:16px; color:#fff }


/* Accessibility focus */
.hero-pitch .flip-card[role="button"]:focus{
  outline: 2px solid #93c5fd; outline-offset: 3px;
  border-radius: calc(var(--radius) + 2px);
}


/* --- Clean, non-overlapping layout for the BACK face only --- */
.flip-face.flip-back .player-card{
  display: flex;            /* establish a layout context */
  flex-direction: column;
    justify-content:flex-start;

}

/* Name block participates in flow (no absolute), sits near the top */
.flip-face.flip-back .nameblock{
  position:relative;          /* was absolute */
  z-index:2;
  top:auto; left:auto; transform:none;
  width: 96%;                 /* less “outside” margin than before */
  margin: 14px auto 8px;      /* top spacing, then small gap to stats */
  padding: 0 4px;
  padding-top: 35px;
  text-align:center;
  display:flex; flex-direction:column; gap:6px; align-items:center;
}


/* One-line, centered, ellipsis for long text */
.flip-face.flip-back .lastname,
.flip-face.flip-back .back-pos{
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
}

.flip-face.flip-back .info{
  display: grid;
  grid-template-columns: 1fr auto;     /* text | badge */
  grid-auto-rows: min-content;
  column-gap: 12px;
  row-gap: 6px;
  padding: 16px;                        /* a bit more breathing room */
}

/* Make the badge part of the flow on the back (not absolute) */
.flip-face.flip-back .badge{
  position: static;
  grid-column: 2;                       /* right column */
  grid-row: 1 / span 2;                 /* align with name+position */
  align-self: start;
  justify-self: end;
}

/* Tweak sizes a touch smaller to avoid overlap */
.flip-face.flip-back .lastname{
  font-size: 10px;
  line-height:1.05;
}
.flip-face.flip-back .back-pos{
  font-size: 9px;
  letter-spacing:.16em;
}


/* Header text placement */
.flip-face.flip-back .name{
  grid-column: 1;
  grid-row: 1;
  margin: 0;
}
.flip-face.flip-back .position{
  grid-column: 1;
  grid-row: 2;
  margin: 0 0 8px 0;
  color: #cbd5e1;
}

/* Stats block spans full width below header */
.flip-face.flip-back .stats{
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr)); /* prevent overflow */
  gap: 10px;
  margin-top: 6px;
}

.flip-face.flip-back .stat{
  display: grid;
  place-items: center;
  gap: 4px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  padding: 12px;
  border-radius: 12px;
  min-height: 56px;                     /* keeps tiles even */
}

/* Text safety: avoid accidental overflow in narrow cards */
.flip-face.flip-back .name,
.flip-face.flip-back .position{
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bg-img{
  position:absolute; inset:0; z-index:0;
  width:100%; height:100%;
  object-fit:cover; object-position:center;
  filter:saturate(1.08) contrast(1.04);
  display:block;

}


/* Keep your BGs. We just re-pin the front info to the bottom edge */
.player-card .info{ position:absolute; inset:auto 0 0 0; padding:0; background:none; z-index:3; }

/* FRONT: angled ribbon that enters from the left */
.info--front .tagline{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:6px;
  padding: 6px 12px 6px;
  margin: 0;          /* hugs left edge */
  border-radius: 0 14px 14px 0;
  background:
    linear-gradient(90deg, rgba(8,12,26,.92) 0%, rgba(8,12,26,.70) 60%, rgba(8,12,26,.35) 100%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.06) 0 6px, transparent 6px 12px);
  box-shadow: 0 10px 28px rgba(0,0,0,.35);
  transform: skewX(-12deg);          /* angled strip */
  animation: tag-slide-in .55s cubic-bezier(.2,.8,.2,1) both;
}

/* little nose so it feels like it “comes from” the left side */
.info--front .tagline::before{
  content:""; position:absolute; left:-42px; top:0; bottom:0; width:42px;
  background: linear-gradient(90deg, rgba(8,12,26,.92), rgba(8,12,26,.75));
  clip-path: polygon(100% 0, 0 0, 100% 100%);
  filter: drop-shadow(0 6px 16px rgba(0,0,0,.35));
}

/* gold accent line on top edge */
.info--front .tagline::after{
  content:""; position:absolute; left:0; right:0; top:0; height:2px;
  background: linear-gradient(90deg, var(--gold), transparent);
  opacity:.9;
}

/* Un-skew the text so it reads straight */
.info--front .name,
.info--front .position{ transform: skewX(12deg); }

/* Typography inside the ribbon */
.info--front .name{
  margin:0;
  font-size: clamp(14px, 1.6vw, 16px);     /* was 18–24px */
  font-weight: 700; letter-spacing:.2px; line-height:1;
  color:#fff; text-shadow: 0 1px 0 rgba(0,0,0,.35);
    transform: skewX(12deg);
  max-width: 100%;                          /* avoid running into jersey */
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.info--front .position{
  margin:0 0 0 2px;
  font-size: clamp(10px, 1vw, 12px);
  font-weight: 900; line-height:1;
  text-transform: uppercase; letter-spacing:.18em;
  transform: skewX(12deg);
  color: color-mix(in oklab, #ffffff 86%, var(--gold) 14%);
  opacity:.95;
}


/* Entry animation */
@keyframes tag-slide-in{
  from{ transform: translateX(-18%) skewX(-12deg); opacity:0; }
  to  { transform: translateX(0)    skewX(-12deg); opacity:1; }
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .info--front .tagline{ animation: none; }
}
/* (Optional but helpful) predictable sizing everywhere */
*, *::before, *::after { box-sizing: border-box; }




/* Centered stack for lastname + position on the back */
/* Centered stack with tighter sides */
.nameblock{
  position:absolute; z-index:3;
  left:50%; top:24%;
  transform: translateX(-50%);
  width: 88%;              /* less side “padding” without changing the layout */
  padding: 0 6px;          /* tiny breathing room so ellipsis doesn’t touch edge */
  text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:8px;
}

/* One-line, centered, ellipsis for overflow */
.lastname,
.back-pos{
  max-width:100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Last name */
.lastname{
  margin:0;
  font-size: clamp(16px, 1.7vw, 20px);      /* was 18–24px */
  font-weight:1000;
  letter-spacing:.02em;
  text-transform:uppercase;
  color:#fff;
  line-height:1.05;
  text-shadow:0 1px 0 rgba(0,0,0,.35);
}

/* Position directly under last name */
.back-pos{
  font-size: clamp(9px, .9vw, 11px);        /* was 12px */
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#e8ecf7;
  opacity:.9;
}

/* Small screens: slightly wider block + smaller type so long names still fit */
@media (max-width:1200px){
  .nameblock{ width:96%; top:26%; }
  .lastname{ font-size: clamp(16px, 4.2vw, 22px); }
}

@media (min-width: 1200px){
  .flip-face.flip-back .statpairs{
  padding: 0 !important;
   gap: 0 !important;
}
  .flip-face.flip-back .statpairs strong{
  font-size: 12px !important;
  line-height:1 !important; font-weight:600 !important;
  margin-right:3px !important;
}
.flip-face.flip-back .statpairs em{
  font-size: 10px !important ;
  font-weight:400 !important;
}
.flip-face.flip-back .statpairs .pair + .pair{ margin-top: 1px !important; }

}
/* Stat block – more compact, still bold, no crowding the name */
.flip-face.flip-back .statpairs{
  position:relative;          /* was absolute bottom */
  z-index:2;
  width: 96%;                 /* closer to card edges (less outside margin) */
  margin: 6px auto 12px;      /* small outer margin */
  padding: clamp(10px, 1.4vw, 16px);
  min-height: auto;           /* let content define height */
  display:grid; gap: clamp(8px, 1.2vw, 14px);
  align-content:center;

  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.10));
  border: 1px solid rgba(255,255,255,.24);
  backdrop-filter: blur(8px) saturate(120%);
}

/* Center divider remains, shortened a bit */
.flip-face.flip-back .statpairs::before{
  content:"";
  position:absolute; left:50%;
  top: 8px; bottom: 8px;      /* slightly less than before */
  width:2px; transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(255,255,255,.42), rgba(255,255,255,.12));
  border-radius: 2px;
}

.flip-face.flip-back .statpairs .pair{
  display:grid; grid-template-columns: 1fr 1fr; align-items:center;
}
.flip-face.flip-back .statpairs .lhs{ text-align:left; }
.flip-face.flip-back .statpairs .rhs{ text-align:right; }

.flip-face.flip-back .statpairs strong{
  font-size: clamp(18px, 3.2vw, 24px);
  line-height:1.05; font-weight:1000; color:#fff; margin-right:6px;
  text-shadow: 0 2px 8px rgba(0,0,0,.32), 0 1px 0 rgba(0,0,0,.35);
}
.flip-face.flip-back .statpairs em{
  font-style:normal; font-size: clamp(10px, 1vw, 13px);
  font-weight:900; letter-spacing:.08em; text-transform:uppercase;
  color:#e8ecf7; opacity:.98;
}
.flip-face.flip-back .statpairs .pair + .pair{ margin-top: clamp(2px, .6vw, 6px); }

/* Small screens: keep everything readable and inside */
@media (max-width:1200px){
  .flip-face.flip-back .nameblock{ width:98%; margin-top: 12px; }
  .flip-face.flip-back .lastname{ font-size: clamp(15px, 4vw, 18px); }
  .flip-face.flip-back .statpairs{
    width:98%;
    margin: 6px auto 10px;
    padding: clamp(10px, 3vw, 14px);
  }
}



#news, #shop, #upcoming, #teams, #partners {
  content-visibility: auto;
  contain-intrinsic-size: 800px; /* rough placeholder height */
}

/* Mobile: swap blur glass for flat translucent bg */
@media (max-width: 640px){
  .news-glass, .match-card { backdrop-filter: none; -webkit-backdrop-filter:none;
    background: rgba(255,255,255,.9); border-color: rgba(0,0,0,.06);
  }
}
/* Only create layers on hover; remove global will-change */
.partners .logo-card { will-change: auto; }
.partners .logo-card:hover { will-change: transform; }


@media (max-width: 640px){
  .player-img.player-img--lg { filter: drop-shadow(0 10px 20px rgba(0,0,0,.35)); width: 94%; }
}



/* ---------- CTA ---------- */
.sponsor-cta{
  margin-block: clamp(24px, 5vw, 48px);
}
.sponsor-cta .cta-card{
  text-align: center;
  padding: clamp(18px, 4vw, 36px);
  border-radius: 18px;
  background:
    radial-gradient(1200px 480px at 50% -140px, rgba(59,130,246,.18), rgba(59,130,246,0)),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 12px 34px rgba(2,6,23,.16);
}
.sponsor-cta .cta-card h3{ margin: 0 0 6px; color: #fff; }
.sponsor-cta .cta-card p{ margin: 0 0 14px; color: #cbd5e1; }
.sponsor-cta .btn{
  display:inline-block; padding: 10px 16px; border-radius: 999px; font-weight: 700;
  background: #2563eb; color:#fff; text-decoration:none; border:1px solid rgba(255,255,255,.2);
}
.sponsor-cta .btn:hover{ filter: brightness(1.05); transform: translateY(-1px); }

/* ---------- Premium banner ---------- */
/* PREMIUM list: wrap into rows, no scrolling */
.premium-banner {
  padding-bottom: 30px;
}
/* --- PREMIUM BANNER: flush edges, no side padding/margins --- */
.premium-list{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: clamp(12px, 1.6vw, 20px);
  margin: 0;                 /* no left/right margin */
  padding: 0;                /* no left/right padding */
}

/* If your page has a padded .wrap around the banner, unpad it here */
.wrap-premium{ padding-inline: 0;}

/* --- PREMIUM CARD: taller tile, clean crop, centered both ways --- */
.premium-card{
  position: relative;              /* <-- make img absolutely centered inside */
  display: block;
  height: 450px;                   /* your desired tall size */
  border-radius: 16px;
  overflow: hidden;
  background: #000;
  box-shadow: 0 10px 26px rgba(0,0,0,.18);
}

/* Image: fill box, crop, and be perfectly centered */
.premium-card img{
  position: absolute;              /* <-- eliminates any layout influence */
  inset: 0;                        /* top:0 right:0 bottom:0 left:0 */
  width: 100%;
  height: 100%;
  object-fit: contain;               /* crop to fill */
  object-position: 50% 50%;        /* center horizontally & vertically */
  display: block;
}

@media (max-width: 640px) {
  .premium-card{
    height: clamp(140px, 40vw, 220px); /* slightly shorter is nicer on phones */
  }
  .premium-card img{
    object-fit: contain;           /* show entire image */
    object-position: center center;
    /* keep these from your current setup */
    position: absolute;
    width: 100%;
    height: 100%;
    display: block;
  }
}
