/* ============================================================
   WP FORMATION SHORTCODE — CSS v9.0.0
   Design System: Light Mode (Lulus Uji Aksesibilitas)
   Font: System font stack
   ============================================================ */

/* ============================
   1. DESIGN TOKENS (CSS Variables)
   ============================ */
:root {
  /* Warna Dasar */
  --wpfm-bg-0:       #f9fafb;
  --wpfm-bg-1:       #ffffff;
  --wpfm-bg-2:       #f3f4f6;
  --wpfm-bg-3:       #e5e7eb;
  --wpfm-bg-4:       #d1d5db;
  --wpfm-border:     #e5e7eb;
  --wpfm-border-2:   #d1d5db;

  /* Teks */
  --wpfm-text-1:     #111827;
  --wpfm-text-2:     #374151;
  --wpfm-text-3:     #4b5563; 
  --wpfm-text-4:     #374151; 

  /* Aksen */
  --wpfm-accent:     #3b82f6;
  --wpfm-danger:     #b91c1c; 
  --wpfm-success:    #16a34a;
  --wpfm-warning:    #d97706;

  /* Lapangan */
  --wpfm-pitch-1:    #1e3d24;
  --wpfm-pitch-2:    #19331e;
  --wpfm-pitch-line: rgba(255, 255, 255, 0.4);

  /* Spacing */
  --wpfm-radius:     14px;
  --wpfm-radius-sm:  8px;
  --wpfm-radius-xs:  4px;

  /* Transisi */
  --wpfm-ease:       cubic-bezier(0.4, 0, 0.2, 1);
  --wpfm-duration:   200ms;

  /* Typography */
  --wpfm-font: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI",
               system-ui, Roboto, "Helvetica Neue", Arial, sans-serif;
  --wpfm-font-mono: "SF Mono", "Fira Code", "Cascadia Code", monospace;
}

/* ============================
   2. BASE — Semua Komponen
   ============================ */
.wpfm-card,
.wpfm-match-header,
.wpfm-prediksi,
.wpfm-h2h,
.wpfm-lineup,
.wpfm-absen {
  background:    var(--wpfm-bg-1);
  border:        1px solid var(--wpfm-border);
  border-radius: var(--wpfm-radius);
  margin:        24px 0;
  color:         var(--wpfm-text-1);
  font-family:   var(--wpfm-font);
  overflow:      hidden;
  box-shadow:    0 4px 12px rgba(0, 0, 0, 0.05), 0 1px 3px rgba(0, 0, 0, 0.02);
  position:      relative;
}

.screen-reader-text {
  border:     0;
  clip:       rect(1px, 1px, 1px, 1px);
  clip-path:  inset(50%);
  height:     1px;
  margin:     -1px;
  overflow:   hidden;
  padding:    0;
  position:   absolute;
  width:      1px;
  word-wrap:  normal !important;
}

.wpfm-error {
  background:    #fef2f2;
  border:        1px solid #fecaca;
  border-radius: var(--wpfm-radius-sm);
  color:         var(--wpfm-danger);
  padding:       16px 20px;
  font-size:     14px;
  font-family:   var(--wpfm-font);
  margin:        16px 0;
}

/* ============================
   3. SECTION HEADER
   ============================ */
.wpfm-section-header {
  display:         flex;
  align-items:     center;
  gap:             10px;
  padding:         14px 20px;
  border-bottom:   1px solid var(--wpfm-border);
  font-size:       12px;
  font-weight:     700;
  letter-spacing:  0.8px;
  text-transform:  uppercase;
  color:           var(--wpfm-text-2);
  background:      var(--wpfm-bg-2);
}

.wpfm-header-icon {
  font-size: 14px;
  line-height: 1;
}

.wpfm-header-danger {
  color:          #991b1b;
  background:     #fef2f2;
  border-bottom:  1px solid #fecaca;
}

/* ============================
   4. MATCH HEADER
   ============================ */
.wpfm-match-header {
  padding: 0;
}

.wpfm-mh-competition {
  display:         flex;
  align-items:     center;
  justify-content: center;
  gap:             8px;
  padding:         10px 20px;
  font-size:       11px;
  font-weight:     600;
  letter-spacing:  1.2px;
  text-transform:  uppercase;
  color:           var(--wpfm-text-2);
  background:      var(--wpfm-bg-2);
  border-bottom:   1px solid var(--wpfm-border);
}

.wpfm-mh-comp-dot {
  width:         5px;
  height:        5px;
  border-radius: 50%;
  background:    var(--wpfm-success);
  animation:     wpfm-pulse 2s ease infinite;
}

@keyframes wpfm-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%        { opacity: 0.5; transform: scale(0.7); }
}

.wpfm-mh-body {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  gap:             16px;
  padding:         28px 24px;
}

.wpfm-mh-team {
  flex:            1;
  display:         flex;
  flex-direction:  column;
  align-items:     center;
  gap:             10px;
  min-width:       0;
}

.wpfm-mh-logo {
  position:        relative;
  width:           68px;
  height:          68px;
  display:         flex;
  align-items:     center;
  justify-content: center;
  border-radius:   50%;
  background:      var(--wpfm-bg-1);
  border:          2px solid var(--wpfm-border-2);
  overflow:        hidden;
  flex-shrink:     0;
  transition:      transform var(--wpfm-duration) var(--wpfm-ease),
                   box-shadow var(--wpfm-duration) var(--wpfm-ease);
}

.wpfm-mh-logo:hover {
  transform:  scale(1.05);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--team-color, #888) 25%, transparent);
}

.wpfm-logo-img {
  width:      100%;
  height:     100%;
  object-fit: contain;
  padding:    6px;
}

.wpfm-logo-fallback {
  width:           100%;
  height:          100%;
  display:         flex;
  align-items:     center;
  justify-content: center;
  font-size:       22px;
  font-weight:     800;
  color:           #fff;
  letter-spacing:  -0.5px;
  text-shadow:     0 1px 3px rgba(0,0,0,0.3);
}

.wpfm-mh-name {
  font-size:      15px;
  font-weight:    600;
  color:          var(--wpfm-text-1);
  text-align:     center;
  margin:         0;
  padding:        0;
  line-height:    1.3;
  letter-spacing: 0.2px;
  border:         none;
}

.wpfm-match-header h2.wpfm-mh-name {
  font-size:        15px;
  font-weight:      600;
  color:            var(--wpfm-text-1);
  background:       none;
  padding:          0;
  border:           none;
  box-shadow:       none;
  text-transform:   none;
  letter-spacing:   0.2px;
  line-height:      1.3;
  margin:           0;
}

.wpfm-mh-label {
  font-size:      11px;
  color:          var(--wpfm-text-3);
  font-weight:    500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.wpfm-mh-center {
  display:         flex;
  flex-direction:  column;
  align-items:     center;
  gap:             10px;
  flex-shrink:     0;
  min-width:       90px;
}

.wpfm-mh-meta {
  display:         flex;
  flex-direction:  column;
  align-items:     center;
  gap:             3px;
}

.wpfm-mh-date,
.wpfm-mh-time {
  font-size:   11px;
  color:       var(--wpfm-text-3);
  font-weight: 500;
  display:     block;
  text-align:  center;
}

.wpfm-mh-time {
  color:       var(--wpfm-text-2);
  font-weight: 600;
}

.wpfm-mh-score {
  font-size:      36px;
  font-weight:    800;
  color:          var(--wpfm-text-1);
  font-family:    var(--wpfm-font-mono);
  letter-spacing: -1px;
  line-height:    1;
}

.wpfm-mh-score.is-live {
  color: var(--wpfm-success);
}

.wpfm-mh-colorbar {
  height:       3px;
  width:        100%;
  flex-shrink:  0;
}

/* ============================
   5. LAPANGAN (PITCH) & HEADER DUEL
   ============================ */
.wpfm-card {
  padding: 0;
}

.wpfm-card-header {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  padding:         14px 18px;
  border-bottom:   1px solid var(--wpfm-border);
  background:      var(--wpfm-bg-2);
}

.wpfm-header-duel {
  justify-content: space-between;
}

.wpfm-team-header {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0; 
}

.wpfm-team-header.away {
  flex-direction: row-reverse;
}

.wpfm-card-title {
  display:     flex;
  align-items: center;
  gap:         8px;
  font-size:   14px;
  font-weight: 600;
  color:       var(--wpfm-text-1);
}

.wpfm-team-name {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 150px; 
}

.wpfm-dot {
  width:         10px;
  height:        10px;
  border-radius: 50%;
  display:       inline-block;
  flex-shrink:   0;
}

.wpfm-formation-badge {
  background:    var(--wpfm-bg-4);
  color:         var(--wpfm-text-2);
  padding:       4px 10px;
  border-radius: 20px;
  font-size:     11px;
  font-weight:   700;
  border:        1px solid var(--wpfm-border-2);
  font-family:   var(--wpfm-font-mono);
  letter-spacing: 0.5px;
  white-space:   nowrap; 
  flex-shrink:   0;
}

.wpfm-vs-text {
  font-size:      11px;
  font-weight:    800;
  color:          var(--wpfm-text-4);
  letter-spacing: 1px;
  margin:         0 16px;
  flex-shrink:    0;
}

.wpfm-pitch {
  position:     relative;
  width:        100%;
  aspect-ratio: 16 / 9;
  overflow:     hidden;
  background: repeating-linear-gradient(
    90deg,
    var(--wpfm-pitch-1) 0,
    var(--wpfm-pitch-1) 10%,
    var(--wpfm-pitch-2) 10%,
    var(--wpfm-pitch-2) 20%
  );
  box-shadow: inset 0 0 60px rgba(0, 0, 0, 0.3);
}

.wpfm-pitch-label {
  position:        absolute;
  top:             50%;
  left:            50%;
  transform:       translate(-50%, -50%);
  font-size:       10px;
  font-weight:     700;
  color:           rgba(255,255,255,0.25);
  text-transform:  uppercase;
  letter-spacing:  2px;
  pointer-events:  none;
  white-space:     nowrap;
}

/* ============================
   5a. GARIS LAPANGAN
   ============================ */
.wpfm-outline,
.wpfm-halfway,
.wpfm-center-circle,
.wpfm-center-spot,
.wpfm-box,
.wpfm-goal-box,
.wpfm-penalty-spot,
.wpfm-arc,
.wpfm-corner {
  position: absolute;
}

.wpfm-outline {
  inset:  10px;
  border: 1.5px solid var(--wpfm-pitch-line);
}

.wpfm-halfway {
  left:       50%;
  top:        10px;
  bottom:     10px;
  width:      1.5px;
  background: var(--wpfm-pitch-line);
  transform:  translateX(-50%);
}

.wpfm-center-circle {
  width:         18%;
  aspect-ratio:  1;
  left:          50%;
  top:           50%;
  transform:     translate(-50%, -50%);
  border-radius: 50%;
  border:        1.5px solid var(--wpfm-pitch-line);
}

.wpfm-center-spot {
  width:         5px;
  height:        5px;
  background:    var(--wpfm-pitch-line);
  border-radius: 50%;
  left:          50%;
  top:           50%;
  transform:     translate(-50%, -50%);
}

.wpfm-box.left,
.wpfm-box.right {
  top:       50%;
  transform: translateY(-50%);
  height:    50%;
  width:     14%;
  border:    1.5px solid var(--wpfm-pitch-line);
}
.wpfm-box.left  { left: 10px; border-left: none; }
.wpfm-box.right { right: 10px; border-right: none; }

.wpfm-goal-box.left,
.wpfm-goal-box.right {
  top:       50%;
  transform: translateY(-50%);
  height:    22%;
  width:     5.5%;
  border:    1.5px solid var(--wpfm-pitch-line);
}
.wpfm-goal-box.left  { left: 10px; border-left: none; }
.wpfm-goal-box.right { right: 10px; border-right: none; }

.wpfm-penalty-spot.left,
.wpfm-penalty-spot.right {
  width:         4px;
  height:        4px;
  background:    var(--wpfm-pitch-line);
  border-radius: 50%;
  top:           50%;
  transform:     translateY(-50%);
}
.wpfm-penalty-spot.left  { left:  calc(10px + 10%); }
.wpfm-penalty-spot.right { right: calc(10px + 10%); }

.wpfm-arc.left,
.wpfm-arc.right {
  top:           50%;
  transform:     translateY(-50%);
  height:        20%;
  aspect-ratio:  1;
  border-radius: 50%;
  border:        1.5px solid transparent;
}
.wpfm-arc.left  { left:  calc(10px + 5.5%); border-right-color: var(--wpfm-pitch-line); }
.wpfm-arc.right { right: calc(10px + 5.5%); border-left-color:  var(--wpfm-pitch-line); }

.wpfm-corner {
  width:         10px;
  height:        10px;
  border:        1.5px solid var(--wpfm-pitch-line);
  border-radius: 50%;
}
.wpfm-corner.tl { top:    10px; left:  10px; border-top-color:    transparent; border-left-color:   transparent; }
.wpfm-corner.tr { top:    10px; right: 10px; border-top-color:    transparent; border-right-color:  transparent; }
.wpfm-corner.bl { bottom: 10px; left:  10px; border-bottom-color: transparent; border-left-color:   transparent; }
.wpfm-corner.br { bottom: 10px; right: 10px; border-bottom-color: transparent; border-right-color:  transparent; }

/* ============================
   5b. TITIK PEMAIN
   ============================ */
.wpfm-player {
  position:        absolute;
  width:           22px;
  height:          22px;
  border-radius:   50%;
  transform:       translate(-50%, -50%);
  border:          2px solid rgba(255, 255, 255, 0.9);
  box-shadow:      0 2px 6px rgba(0, 0, 0, 0.4);
  z-index:         10;
  display:         flex;
  align-items:     center;
  justify-content: center;
  cursor:          default;
  transition:      transform var(--wpfm-duration) var(--wpfm-ease),
                   box-shadow var(--wpfm-duration) var(--wpfm-ease);
}

.wpfm-player:hover {
  transform:  translate(-50%, -50%) scale(1.25);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
  z-index:    20;
}

.wpfm-player.home { background: var(--home, #3b82f6); }
.wpfm-player.away { background: var(--away, #ef4444); }

.wpfm-player-num {
  font-size:      8.5px; 
  font-weight:    800;
  color:          #ffffff;
  line-height:    1;
  font-family:    var(--wpfm-font-mono);
  pointer-events: none;
  user-select:    none;
  text-shadow:    0px 0px 2px rgba(0, 0, 0, 0.9), 
                  0px 1px 3px rgba(0, 0, 0, 0.9);
}

.wpfm-duel-legend {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  padding:         12px 18px;
  border-top:      1px solid var(--wpfm-border);
  background:      var(--wpfm-bg-2);
}

.wpfm-legend-item {
  display:     flex;
  align-items: center;
  gap:         8px;
  font-size:   12px;
  color:       var(--wpfm-text-2);
  font-weight: 500;
}

.wpfm-legend-dot {
  width:         10px;
  height:        10px;
  border-radius: 50%;
  display:       inline-block;
  flex-shrink:   0;
}

/* ============================
   6. PREDIKSI SKOR
   ============================ */
.wpfm-prediksi {
  padding: 0;
}

.wpfm-prediksi-body {
  display:         flex;
  align-items:     center;
  justify-content: center;
  gap:             20px;
  padding:         28px 24px;
}

.wpfm-prediksi-team {
  flex:        1;
  font-size:   16px;
  font-weight: 600;
  color:       var(--wpfm-text-1);
  line-height: 1.3;
}

.wpfm-prediksi-team.home { text-align: right; }
.wpfm-prediksi-team.away { text-align: left; }

.wpfm-prediksi-score {
  background:      var(--wpfm-bg-2);
  color:           var(--wpfm-text-1);
  font-size:       26px;
  font-weight:     800;
  font-family:     var(--wpfm-font-mono);
  padding:         10px 22px;
  border-radius:   var(--wpfm-radius-sm);
  border:          1px solid var(--wpfm-border-2);
  min-width:       72px;
  text-align:      center;
  letter-spacing:  -0.5px;
  flex-shrink:     0;
}

.wpfm-prediksi-analysis {
  border-top:  1px solid var(--wpfm-border);
  padding:     16px 20px;
  background:  var(--wpfm-bg-2);
  font-size:   14px;
  line-height: 1.7;
  color:       var(--wpfm-text-2);
  margin:      0;
}

.wpfm-prediksi-analysis p {
  margin: 0 0 8px;
}
.wpfm-prediksi-analysis p:last-child {
  margin-bottom: 0;
}

/* ============================
   7. HEAD TO HEAD (Premium Layout)
   ============================ */
.wpfm-h2h {
  padding: 0;
  background: #f8fafc; 
  border-radius: var(--wpfm-radius);
}

.wpfm-h2h-list {
  background: transparent;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px; 
}

.wpfm-h2h-row {
  background: #ffffff; 
  padding: 16px 20px;
  border: 1px solid var(--wpfm-border);
  border-radius: 10px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.02); 
}

.wpfm-h2h-row:hover {
  border-color: #cbd5e1;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.04);
}

.wpfm-h2h-meta {
  display: grid;
  grid-template-columns: 1fr auto 1fr; 
  align-items: center;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid #f1f5f9; 
}

.wpfm-h2h-date {
  grid-column: 1;
  font-size: 11px;
  color: var(--wpfm-text-3);
  font-weight: 600;
  text-align: left;
}

.wpfm-h2h-comp {
  grid-column: 2; 
  font-size: 10px;
  color: var(--wpfm-text-1);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  background: var(--wpfm-bg-3);
  padding: 4px 12px;
  border-radius: 20px;
  text-align: center;
}

.wpfm-h2h-result {
  display: flex;
  align-items: center;
  justify-content: center; 
  gap: 16px;
}

.wpfm-h2h-team {
  flex: 1;
  font-size: 14px;
  font-weight: 600; 
  color: var(--wpfm-text-1);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wpfm-h2h-team.home { text-align: right; }
.wpfm-h2h-team.away { text-align: left; }

.wpfm-h2h-score {
  background: #1e293b; 
  color: #ffffff; 
  font-weight: 800;
  font-family: var(--wpfm-font-mono);
  padding: 6px 16px;
  border-radius: 6px; 
  font-size: 14px;
  min-width: 56px;
  text-align: center;
  letter-spacing: 1px;
  flex-shrink: 0;
  border: none;
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.2); 
}

/* ============================
   8. LINEUP (SUSUNAN PEMAIN)
   ============================ */
.wpfm-lineup {
  padding: 0;
}

.wpfm-lineup-grid {
  display:               grid;
  grid-template-columns: 1fr 1px 1fr;
  background:            var(--wpfm-bg-1);
}

.wpfm-lineup-divider {
  background: var(--wpfm-border);
  align-self: stretch;
}

.wpfm-lineup-team-name {
  background:     var(--wpfm-bg-2);
  padding:        12px 16px;
  font-size:      12px;
  font-weight:    700;
  color:          var(--wpfm-text-1);
  border-bottom:  1px solid var(--wpfm-border);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.wpfm-lineup-col.home .wpfm-lineup-team-name { text-align: right; }
.wpfm-lineup-col.away .wpfm-lineup-team-name { text-align: left; }

.wpfm-lineup-list {
  list-style: none;
  padding:    0;
  margin:     0;
}

.wpfm-lineup-list li {
  padding:       10px 16px;
  border-bottom: 1px solid var(--wpfm-border);
  font-size:     13px;
  color:         var(--wpfm-text-2);
  transition:    background var(--wpfm-duration) var(--wpfm-ease),
                 color var(--wpfm-duration) var(--wpfm-ease);
  line-height:   1.4;
}

.wpfm-lineup-list li:hover {
  background: var(--wpfm-bg-2);
  color:      var(--wpfm-text-1);
}

.wpfm-lineup-list li:last-child {
  border-bottom: none;
}

.wpfm-lineup-col.home .wpfm-lineup-list li { text-align: right; }
.wpfm-lineup-col.away .wpfm-lineup-list li { text-align: left; }

.wpfm-coach-row {
  font-weight: 600 !important;
  color:       var(--wpfm-text-1) !important;
  background:  var(--wpfm-bg-2) !important;
  border-top:  1px solid var(--wpfm-border) !important;
  font-style:  italic;
}

.wpfm-lineup-footer {
  display:     flex;
  align-items: flex-start;
  gap:         10px;
  padding:     14px 20px;
  font-size:   13px;
  line-height: 1.6;
  border-top:  1px solid var(--wpfm-border);
}

.wpfm-footer-label {
  font-weight:    700;
  font-size:      11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  white-space:    nowrap;
  flex-shrink:    0;
  margin-top:     2px;
}

.wpfm-absen-inline {
  background: #fef2f2;
  color:      var(--wpfm-danger);
}

.wpfm-absen-inline .wpfm-footer-label {
  color: var(--wpfm-danger);
}

.wpfm-catatan-inline {
  background: var(--wpfm-bg-2);
  color:      var(--wpfm-text-2);
}

.wpfm-catatan-inline .wpfm-footer-label {
  color: var(--wpfm-warning);
}

/* ============================
   9. PEMAIN ABSEN (STANDALONE)
   ============================ */
.wpfm-absen {
  padding: 0;
}

.wpfm-absen-grid {
  display:               grid;
  grid-template-columns: 1fr 1px 1fr;
  background:            var(--wpfm-bg-1);
}

.wpfm-absen-divider {
  background: #fecaca;
  align-self: stretch;
}

.wpfm-absen-team {
  padding:        12px 16px;
  font-size:      12px;
  font-weight:    800;
  color:          #991b1b;
  background:     #fef2f2;
  border-bottom:  1px solid #fecaca;
  text-align:     center;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.wpfm-absen-players {
  padding:     16px;
  font-size:   13px;
  color:       var(--wpfm-text-2);
  line-height: 1.7;
  text-align:  center;
}

.wpfm-absen-note {
  display:     flex;
  align-items: flex-start;
  gap:         10px;
  background:  var(--wpfm-bg-1);
  border-top:  1px solid #fecaca;
  padding:     14px 20px;
  font-size:   13px;
  color:       var(--wpfm-text-3);
  line-height: 1.6;
}

/* ============================
   10. RESPONSIVE MOBILE
   ============================ */
@media (max-width: 640px) {
  /* Match Header */
  .wpfm-mh-body          { padding: 20px 14px; gap: 10px; }
  .wpfm-mh-logo          { width: 52px; height: 52px; }
  .wpfm-logo-fallback    { font-size: 18px; }
  .wpfm-match-header h2.wpfm-mh-name { font-size: 12px; }
  .wpfm-mh-score         { font-size: 28px; }
  .wpfm-mh-center        { min-width: 60px; }

  /* Formasi Lapangan */
  .wpfm-player           { width: 18px; height: 18px; }
  .wpfm-player-num       { font-size: 6.5px; }

  /* Prediksi Skor */
  .wpfm-prediksi-body    { padding: 20px 14px; gap: 10px; }
  .wpfm-prediksi-team    { font-size: 14px; }
  .wpfm-prediksi-score   { font-size: 20px; min-width: 56px; padding: 8px 14px; }

  /* Head to Head (H2H) Update Layout Baru */
  .wpfm-h2h-list         { padding: 8px; gap: 8px; }
  .wpfm-h2h-row          { padding: 12px; }
  .wpfm-h2h-meta {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding-bottom: 10px;
    margin-bottom: 10px;
  }
  .wpfm-h2h-date         { text-align: center; font-size: 10px; }
  .wpfm-h2h-team         { font-size: 13px; }
  .wpfm-h2h-score        { font-size: 13px; min-width: 48px; padding: 4px 10px; margin: 0 6px; }

  /* Lineup & Section Lainnya */
  .wpfm-lineup-list li   { padding: 8px 12px; font-size: 12px; }
  .wpfm-lineup-team-name { padding: 10px 12px; font-size: 11px; }
  .wpfm-absen-players    { padding: 12px; font-size: 12px; }
  .wpfm-section-header   { padding: 12px 14px; font-size: 11px; }
  .wpfm-lineup-footer    { padding: 12px 14px; font-size: 12px; }

  /* Penyesuaian Header Formasi Khusus HP agar angka ada di bawah nama tim */
  .wpfm-team-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
  .wpfm-team-header.away {
    flex-direction: column;
    align-items: flex-end; 
  }
  .wpfm-card-title {
    font-size: 13px;
  }
  .wpfm-team-name {
    max-width: 100px; 
  }
}

/* Layar HP Sangat Kecil */
@media (max-width: 380px) {
  .wpfm-mh-logo          { width: 42px; height: 42px; }
  .wpfm-mh-score         { font-size: 22px; }
  .wpfm-logo-fallback    { font-size: 15px; }
  .wpfm-prediksi-team    { font-size: 12px; }
  .wpfm-prediksi-score   { font-size: 17px; padding: 6px 10px; min-width: 48px; }
}