/* ──────────────────────────────────────────────────────
   GunnerUp — Arsenal Fan Pulse Stylesheet
   Brand: #EF0008 (Arsenal Red), #FFFFFF, #F6F6F6
   ────────────────────────────────────────────────────── */

:root {
  --gu-red:        #EF0008;
  --gu-red-dark:   #C5000A;
  --gu-red-light:  #FF4D54;
  --gu-gold:       #9C824A;
  --gu-white:      #FFFFFF;
  --gu-bg:         #F6F6F6;
  --gu-card:       #FFFFFF;
  --gu-text:       #1A1A1A;
  --gu-text-muted: #6B7280;
  --gu-border:     #E5E7EB;
  --gu-radius:     12px;
  --gu-shadow:     0 2px 12px rgba(0,0,0,.08);
  --gu-transition: 0.35s cubic-bezier(.4,0,.2,1);
}

/* ── Wrapper ────────────────────────────────────────── */
.gunnerup-pulse-wrap {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  max-width: 560px;
  margin: 0 auto;
}

.gunnerup-pulse {
  background: var(--gu-card);
  border-radius: var(--gu-radius);
  box-shadow: var(--gu-shadow);
  padding: 28px 24px;
  border-top: 4px solid var(--gu-red);
}

/* ── Match Info ─────────────────────────────────────── */
.gunnerup-pulse__match-info {
  text-align: center;
  margin-bottom: 20px;
}

.gunnerup-pulse__competition {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--gu-text-muted);
  margin-bottom: 8px;
}

.gunnerup-pulse__teams {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  font-size: 18px;
  font-weight: 700;
  color: var(--gu-text);
  margin-bottom: 6px;
}

.gunnerup-pulse__vs {
  font-size: 13px;
  font-weight: 400;
  color: var(--gu-text-muted);
}

.gunnerup-pulse__score {
  font-size: 24px;
  font-weight: 800;
  color: var(--gu-red);
  letter-spacing: .04em;
}

.gunnerup-pulse__kickoff {
  font-size: 13px;
  color: var(--gu-text-muted);
}

/* ── Recent Result Context (before-vote) ────────────── */
.gunnerup-pulse__result-context {
  background: var(--gu-bg);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 22px;
  text-align: center;
  border-left: 3px solid var(--gu-red);
}

.gunnerup-pulse__result-context__competition {
  display: block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--gu-text-muted);
  margin-bottom: 8px;
}

.gunnerup-pulse__result-context__row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 6px;
}

.gunnerup-pulse__result-context__team {
  font-size: 15px;
  font-weight: 700;
  color: var(--gu-text);
  flex: 1;
}

.gunnerup-pulse__result-context__team:first-child {
  text-align: right;
}

.gunnerup-pulse__result-context__team:last-child {
  text-align: left;
}

.gunnerup-pulse__result-context__score {
  font-size: 22px;
  font-weight: 800;
  color: var(--gu-red);
  letter-spacing: .04em;
  flex-shrink: 0;
  min-width: 56px;
  text-align: center;
}

.gunnerup-pulse__result-context__score--vs {
  font-size: 13px;
  font-weight: 400;
  color: var(--gu-text-muted);
}

.gunnerup-pulse__result-context__date {
  font-size: 11px;
  color: var(--gu-text-muted);
}

/* ── Prompt ─────────────────────────────────────────── */
.gunnerup-pulse__prompt {
  text-align: center;
  margin-bottom: 24px;
}

.gunnerup-pulse__prompt-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--gu-text);
  margin: 0 0 6px;
}

.gunnerup-pulse__prompt-hint {
  font-size: 13px;
  color: var(--gu-text-muted);
  margin: 0;
}

/* ── Emotion Buttons ────────────────────────────────── */
.gunnerup-pulse__emotions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-bottom: 20px;
}

.gunnerup-pulse__emotion-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 14px 18px;
  background: var(--gu-bg);
  border: 2px solid transparent;
  border-radius: 10px;
  cursor: pointer;
  transition: border-color var(--gu-transition), background var(--gu-transition), transform .15s;
  min-width: 88px;
  flex: 1 1 88px;
  max-width: 120px;
}

.gunnerup-pulse__emotion-btn:hover,
.gunnerup-pulse__emotion-btn:focus-visible {
  border-color: var(--gu-red);
  background: #FFF5F5;
  outline: none;
  transform: translateY(-2px);
}

.gunnerup-pulse__emotion-btn.is-selected {
  border-color: var(--gu-red);
  background: var(--gu-red);
  color: var(--gu-white);
}

.gunnerup-pulse__emotion-btn.is-loading {
  opacity: .6;
  pointer-events: none;
}

.gunnerup-pulse__emotion-emoji {
  font-size: 26px;
  line-height: 1;
}

.gunnerup-pulse__emotion-label {
  font-size: 12px;
  font-weight: 600;
}

.gunnerup-pulse__footer-hint {
  text-align: center;
  font-size: 12px;
  color: var(--gu-text-muted);
  margin: 0;
}

/* ── After Vote: Result Header ──────────────────────── */
.gunnerup-pulse--after {
  animation: gu-fade-in .4s ease both;
}

@keyframes gu-fade-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.gunnerup-pulse__result-header {
  text-align: center;
  margin-bottom: 24px;
}

.gunnerup-pulse__result-emoji {
  display: block;
  font-size: 40px;
  margin-bottom: 8px;
}

.gunnerup-pulse__result-your-vote {
  font-size: 15px;
  color: var(--gu-text-muted);
  margin: 0;
}

/* ── Distribution Bars ──────────────────────────────── */
.gunnerup-pulse__distribution {
  margin-bottom: 24px;
}

.gunnerup-pulse__distribution-title {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--gu-text-muted);
  margin: 0 0 12px;
}

.gunnerup-pulse__bar-row {
  display: grid;
  grid-template-columns: 130px 1fr 38px;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.gunnerup-pulse__bar-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 500;
}

.gunnerup-pulse__bar-emoji {
  font-size: 16px;
}

.gunnerup-pulse__bar-tag {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 99px;
}

.gunnerup-pulse__bar-tag--you {
  background: var(--gu-red);
  color: var(--gu-white);
}

.gunnerup-pulse__bar-tag--most {
  background: #1D1D1D;
  color: var(--gu-white);
}

.gunnerup-pulse__bar-track {
  background: var(--gu-border);
  border-radius: 99px;
  height: 8px;
  overflow: hidden;
}

.gunnerup-pulse__bar-fill {
  height: 100%;
  border-radius: 99px;
  background: var(--gu-text-muted);
  transition: width .7s cubic-bezier(.4,0,.2,1);
}

.is-user-vote .gunnerup-pulse__bar-fill {
  background: var(--gu-red);
}

.is-majority .gunnerup-pulse__bar-fill {
  background: #1D1D1D;
}

.is-user-vote.is-majority .gunnerup-pulse__bar-fill {
  background: var(--gu-red);
}

.gunnerup-pulse__bar-pct {
  font-size: 12px;
  font-weight: 600;
  color: var(--gu-text-muted);
  text-align: right;
}

.gunnerup-pulse__total-votes {
  font-size: 12px;
  color: var(--gu-text-muted);
  margin: 8px 0 0;
  text-align: right;
}

/* ── Insights ───────────────────────────────────────── */
.gunnerup-pulse__insights {
  background: var(--gu-bg);
  border-radius: 10px;
  padding: 16px;
  margin-bottom: 16px;
  text-align: center;
}

.gunnerup-pulse__insight-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-bottom: 12px;
}

.gunnerup-pulse__insight-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  min-width: 80px;
}

.gunnerup-pulse__insight-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--gu-text-muted);
}

.gunnerup-pulse__insight-emoji {
  font-size: 28px;
  line-height: 1;
}

.gunnerup-pulse__insight-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--gu-text);
}

.gunnerup-pulse__insight-box--you .gunnerup-pulse__insight-name {
  color: var(--gu-red);
}

.gunnerup-pulse__insight-arrow {
  font-size: 20px;
  color: var(--gu-text-muted);
}

.gunnerup-pulse__peer-pct {
  font-size: 14px;
  color: var(--gu-text-muted);
  margin: 0;
}

/* ── Anonymous Peer ─────────────────────────────────── */
.gunnerup-pulse__anonymous-peer {
  border-top: 1px solid var(--gu-border);
  padding-top: 16px;
  text-align: center;
}

.gunnerup-pulse__anon-label {
  font-size: 12px;
  color: var(--gu-text-muted);
  margin: 0 0 4px;
}

.gunnerup-pulse__anon-emotion {
  font-size: 15px;
  font-weight: 600;
  color: var(--gu-text);
}

/* ── Error ──────────────────────────────────────────── */
.gunnerup-error {
  color: var(--gu-red);
  font-size: 13px;
  padding: 8px 12px;
  background: #FFF5F5;
  border-left: 3px solid var(--gu-red);
  border-radius: 4px;
}

.gunnerup-pulse__inline-error {
  text-align: center;
  font-size: 13px;
  color: var(--gu-red);
  margin-top: 10px;
}

/* ── Weekly Mood ────────────────────────────────────── */
.gunnerup-weekly-mood {
  background: var(--gu-card);
  border-radius: var(--gu-radius);
  box-shadow: var(--gu-shadow);
  padding: 24px;
  border-top: 4px solid var(--gu-red);
  max-width: 560px;
  margin: 0 auto;
}

.gunnerup-weekly-mood__title {
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--gu-text-muted);
  margin: 0 0 16px;
}

/* ── Fixtures ───────────────────────────────────────── */
.gunnerup-fixtures {
  max-width: 560px;
  margin: 0 auto;
}

.gunnerup-fixture {
  background: var(--gu-card);
  border-radius: var(--gu-radius);
  box-shadow: var(--gu-shadow);
  padding: 16px 20px;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.gunnerup-fixture__teams {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 600;
  font-size: 15px;
}

.gunnerup-fixture__meta {
  font-size: 12px;
  color: var(--gu-text-muted);
  text-align: right;
}

.gunnerup-fixture__score {
  font-size: 18px;
  font-weight: 800;
  color: var(--gu-red);
  letter-spacing: .04em;
}

/* ── Table ──────────────────────────────────────────── */
.gunnerup-table {
  max-width: 700px;
  margin: 0 auto;
  width: 100%;
}

.gunnerup-table table {
  width: 100%;
  border-collapse: collapse;
  background: var(--gu-card);
  border-radius: var(--gu-radius);
  overflow: hidden;
  box-shadow: var(--gu-shadow);
  font-size: 13px;
}

.gunnerup-table th {
  background: #1D1D1D;
  color: var(--gu-white);
  padding: 10px 12px;
  text-align: left;
  font-weight: 600;
}

.gunnerup-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--gu-border);
}

.gunnerup-table tr.is-arsenal td {
  background: #FFF5F5;
  font-weight: 700;
  color: var(--gu-red);
}

/* ── Squad ──────────────────────────────────────────── */
.gunnerup-squad {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 12px;
  max-width: 700px;
  margin: 0 auto;
}

.gunnerup-squad__player {
  background: var(--gu-card);
  border-radius: var(--gu-radius);
  box-shadow: var(--gu-shadow);
  padding: 14px;
  text-align: center;
}

.gunnerup-squad__name {
  font-weight: 700;
  font-size: 13px;
  margin-bottom: 4px;
}

.gunnerup-squad__position {
  font-size: 11px;
  color: var(--gu-text-muted);
  text-transform: uppercase;
}

/* ── News ───────────────────────────────────────────── */
.gunnerup-news {
  max-width: 560px;
  margin: 0 auto;
}

.gunnerup-news__item {
  display: flex;
  gap: 14px;
  background: var(--gu-card);
  border-radius: var(--gu-radius);
  box-shadow: var(--gu-shadow);
  padding: 14px;
  margin-bottom: 10px;
  text-decoration: none;
  color: var(--gu-text);
  transition: box-shadow var(--gu-transition);
}

.gunnerup-news__item:hover {
  box-shadow: 0 4px 20px rgba(0,0,0,.12);
}

.gunnerup-news__thumb {
  width: 72px;
  height: 72px;
  object-fit: cover;
  border-radius: 8px;
  flex-shrink: 0;
}

.gunnerup-news__title {
  font-weight: 700;
  font-size: 14px;
  margin: 0 0 4px;
}

.gunnerup-news__date {
  font-size: 11px;
  color: var(--gu-text-muted);
}

/* ── Upcoming Fixtures (Presence widget) ────────────── */
.gunnerup-upcoming {
  background: var(--gu-card);
  border-radius: var(--gu-radius);
  box-shadow: var(--gu-shadow);
  padding: 20px 24px;
  border-top: 4px solid var(--gu-red);
  max-width: 480px;
  margin: 0 auto;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

.gunnerup-upcoming__title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--gu-text-muted);
  margin: 0 0 16px;
}

.gunnerup-upcoming__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.gunnerup-upcoming__item {
  padding: 14px 0;
  border-bottom: 1px solid var(--gu-border);
}

.gunnerup-upcoming__item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.gunnerup-upcoming__teams {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  font-weight: 700;
  color: var(--gu-text);
  margin-bottom: 5px;
}

.gunnerup-upcoming__vs {
  font-size: 12px;
  font-weight: 400;
  color: var(--gu-text-muted);
}

.gunnerup-upcoming__meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--gu-text-muted);
}

.gunnerup-upcoming__competition {
  font-weight: 600;
}

.gunnerup-upcoming__dot {
  color: var(--gu-border);
}

.gunnerup-upcoming__empty {
  font-size: 13px;
  color: var(--gu-text-muted);
  margin: 0;
}

/* ── Squad — Pitch Formation (Best XI) ──────────────── */
.gunnerup-pitch {
  background: linear-gradient(180deg, #266426 0%, #1d521d 100%);
  border-radius: var(--gu-radius);
  padding: 20px 16px 24px;
  max-width: 480px;
  margin: 0 auto;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  /* subtle pitch lines */
  border: 2px solid rgba(255,255,255,.12);
  position: relative;
}

.gunnerup-pitch::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 72px;
  height: 72px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.15);
  pointer-events: none;
}

.gunnerup-pitch__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}

.gunnerup-pitch__formation {
  font-size: 16px;
  font-weight: 800;
  color: rgba(255,255,255,.95);
  letter-spacing: .04em;
}

.gunnerup-pitch__label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255,255,255,.55);
}

.gunnerup-pitch__field {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.gunnerup-pitch__row {
  display: flex;
  justify-content: space-evenly;
  align-items: flex-start;
}

.gunnerup-pitch__row--gk {
  justify-content: center;
}

.gunnerup-pitch__player {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  min-width: 56px;
}

.gunnerup-pitch__jersey {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--gu-red);
  border: 2px solid rgba(255,255,255,.35);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 14px;
  line-height: 1;
  box-shadow: 0 2px 6px rgba(0,0,0,.35);
}

.gunnerup-pitch__jersey--gk {
  background: #f5a623;
  border-color: rgba(255,255,255,.45);
}

.gunnerup-pitch__name {
  font-size: 10px;
  font-weight: 600;
  color: rgba(255,255,255,.92);
  text-shadow: 0 1px 3px rgba(0,0,0,.6);
  text-align: center;
  max-width: 60px;
  word-break: break-word;
  hyphens: auto;
}

/* ── Squad number badge (full mode) ─────────────────── */
.gunnerup-squad__number {
  font-size: 18px;
  font-weight: 800;
  color: var(--gu-red);
  line-height: 1;
  margin-bottom: 4px;
}

/* ── Responsive ─────────────────────────────────────── */
@media (max-width: 480px) {
  .gunnerup-pulse__bar-row {
    grid-template-columns: 110px 1fr 34px;
  }

  .gunnerup-pulse__emotion-btn {
    min-width: 70px;
    padding: 10px 12px;
  }

  .gunnerup-pulse__teams {
    font-size: 15px;
  }
}
