/* =============================================
   FORCE LÉOPARD — 3-Game World Cup Site
   DRC palette: #007fff (blue) / #f7d618 (yellow) / #ce1021 (red)
   ============================================= */

:root {
  --blue:        #007fff;
  --blue-dark:   #005fcc;
  --blue-xdark:  #003d99;
  --yellow:      #f7d618;
  --yellow-dark: #c4a900;
  --yellow-bg:   #fffbe6;
  --red:         #ce1021;
  --red-dark:    #a00d1a;
  --red-bg:      #fff5f5;
  --white:       #ffffff;
  --off-white:   #f8fafc;
  --dark:        #0d1b2a;
  --text:        #0d1b2a;
  --muted:       #4a5568;
  --faint:       #8ea0b5;
  --divider:     #e2e8f0;
  --border:      #d1d9e0;
  --surface:     rgba(255,255,255,0.98);

  --radius-sm:   6px;
  --radius-md:   10px;
  --radius-lg:   16px;
  --radius-xl:   22px;
  --radius-full: 9999px;

  --shadow-card: 0 8px 40px rgba(13,27,42,0.18), 0 2px 8px rgba(13,27,42,0.08);
  --shadow-sm:   0 2px 8px rgba(13,27,42,0.10);
  --transition:  180ms cubic-bezier(0.16,1,0.3,1);

  --text-xs:   clamp(0.72rem, 0.68rem + 0.2vw, 0.85rem);
  --text-sm:   clamp(0.875rem, 0.8rem + 0.3vw, 1rem);
  --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
  --text-lg:   clamp(1.1rem, 1rem + 0.6vw, 1.45rem);
  --text-xl:   clamp(1.4rem, 1rem + 1.4vw, 2.1rem);
  --text-2xl:  clamp(1.9rem, 0.8rem + 3vw, 3.5rem);
  --text-hero: clamp(2.4rem, 0.2rem + 6.5vw, 6.5rem);

  --font-display: 'Cabinet Grotesk', 'Arial Black', sans-serif;
  --font-body:    'Satoshi', 'Inter', sans-serif;

  --sp-1:0.25rem; --sp-2:0.5rem;  --sp-3:0.75rem; --sp-4:1rem;
  --sp-5:1.25rem; --sp-6:1.5rem;  --sp-8:2rem;    --sp-10:2.5rem;
  --sp-12:3rem;   --sp-16:4rem;   --sp-20:5rem;   --sp-24:6rem;
}

/* === Full-bleed flag background === */
.flag-bg {
  position: fixed; inset: 0; z-index: 0;
  background-image: url('./assets/drc-flag-bg.png');
  background-size: cover; background-position: center;
}
.flag-overlay {
  position: fixed; inset: 0; z-index: 1;
  background: linear-gradient(180deg,
    rgba(0,20,60,0.65) 0%,
    rgba(0,10,40,0.60) 40%,
    rgba(0,8,30,0.75) 100%
  );
}
.page-wrapper {
  position: relative; z-index: 2;
  min-height: 100vh;
  display: flex; flex-direction: column;
  font-family: var(--font-body);
  color: var(--text);
}

/* === Header === */
.site-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-4) var(--sp-8);
  background: rgba(0,18,55,0.60);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom: 2px solid rgba(247,214,24,0.30);
  position: sticky; top: 0; z-index: 50;
}
.header-logo { display:flex; align-items:center; gap:var(--sp-3); }
.logo-wordmark {
  font-family: var(--font-display); font-size: var(--text-lg);
  font-weight: 800; color: var(--white); letter-spacing: -0.02em;
}
.logo-dot { color: var(--yellow); }
.header-contact {
  font-size: var(--text-xs); color: rgba(255,255,255,0.7);
  text-decoration: none; transition: color var(--transition);
}
.header-contact:hover { color: var(--yellow); }

/* === Hero === */
.hero-section {
  padding: var(--sp-16) var(--sp-8) var(--sp-10);
  text-align: center;
}
.hero-inner { max-width: 860px; margin: 0 auto; }
.wc-badge {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-5);
  background: rgba(247,214,24,0.15);
  border: 1.5px solid rgba(247,214,24,0.45);
  border-radius: var(--radius-full);
  font-family: var(--font-display); font-size: var(--text-xs);
  font-weight: 700; color: var(--yellow);
  text-transform: uppercase; letter-spacing: 0.1em;
  margin-bottom: var(--sp-6);
}
.main-title {
  font-family: var(--font-display); font-size: var(--text-hero);
  font-weight: 900; color: var(--white); line-height: 1.05;
  letter-spacing: -0.03em; margin-bottom: var(--sp-5);
  text-shadow: 0 4px 24px rgba(0,0,0,0.5);
}
.title-accent { color: var(--yellow); display: block; }
.hero-sub {
  font-size: var(--text-lg); color: rgba(255,255,255,0.85);
  max-width: 640px; margin: 0 auto var(--sp-8);
  line-height: 1.65; text-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
.hero-sub strong { color: var(--yellow); }

/* Hero nav buttons */
.hero-nav {
  display: flex; flex-wrap: wrap; gap: var(--sp-3);
  justify-content: center;
}
.hero-nav-btn {
  padding: var(--sp-3) var(--sp-6);
  background: var(--blue);
  border: 2px solid var(--blue);
  border-radius: var(--radius-full);
  font-family: var(--font-display); font-size: var(--text-sm);
  font-weight: 700; color: var(--white); text-decoration: none;
  transition: background var(--transition), border-color var(--transition), transform var(--transition), box-shadow var(--transition);
  box-shadow: 0 4px 16px rgba(0,127,255,0.35);
}
.hero-nav-btn:hover { background: var(--blue-dark); border-color: var(--blue-dark); transform: translateY(-2px); color: var(--white); box-shadow: 0 6px 22px rgba(0,127,255,0.50); }

/* June 23 — Gold/Yellow */
.hero-nav-btn--gold {
  background: var(--yellow);
  border-color: var(--yellow);
  color: var(--dark);
  box-shadow: 0 4px 16px rgba(196,169,0,0.40);
}
.hero-nav-btn--gold:hover { background: var(--yellow-dark); border-color: var(--yellow-dark); color: var(--dark); box-shadow: 0 6px 22px rgba(196,169,0,0.55); }

/* June 27 — Red */
.hero-nav-btn--red {
  background: var(--red);
  border-color: var(--red);
  color: var(--white);
  box-shadow: 0 4px 16px rgba(206,16,33,0.35);
}
.hero-nav-btn--red:hover { background: var(--red-dark); border-color: var(--red-dark); transform: translateY(-2px); color: var(--white); box-shadow: 0 6px 22px rgba(206,16,33,0.50); }

/* === Guarantee banner === */
.guarantee-banner {
  display: flex; align-items: center; gap: var(--sp-4);
  margin: 0 var(--sp-8) var(--sp-2);
  padding: var(--sp-4) var(--sp-6);
  background: rgba(247,214,24,0.14);
  border: 1.5px solid rgba(247,214,24,0.35);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm); color: rgba(255,255,255,0.9);
  line-height: 1.55;
}
.guarantee-banner-icon { font-size: 1.6rem; flex-shrink: 0; }
.guarantee-banner strong { color: var(--yellow); }

/* === Game Sections === */
.game-section {
  padding: var(--sp-10) var(--sp-8);
}
.game-section--alt {
  background: rgba(0,0,0,0.10);
}
.game-section-inner {
  max-width: 1160px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--sp-8); align-items: start;
}
.game-section-inner--rev { direction: rtl; }
.game-section-inner--rev > * { direction: ltr; }

/* === Match card (game display) === */
.match-card {
  background: rgba(255,255,255,0.10);
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
  border: 1.5px solid rgba(255,255,255,0.22);
  border-radius: var(--radius-xl);
  padding: var(--sp-8); text-align: center;
  transition: transform var(--transition), background var(--transition);
  position: sticky; top: 80px;
}
.match-card:hover { background: rgba(255,255,255,0.16); transform: translateY(-2px); }
.match-card--gold { border-color: rgba(247,214,24,0.35); }
.match-card--red  { border-color: rgba(206,16,33,0.35); }

.match-date-pill {
  display: inline-block;
  background: var(--blue); color: var(--white);
  font-family: var(--font-display); font-size: var(--text-xs);
  font-weight: 800; text-transform: uppercase; letter-spacing: 0.08em;
  padding: var(--sp-1) var(--sp-5); border-radius: var(--radius-full);
  margin-bottom: var(--sp-6);
}
.match-date-pill--gold { background: var(--yellow); color: var(--dark); }
.match-date-pill--red  { background: var(--red); color: var(--white); }

.match-matchup {
  display: flex; align-items: center; justify-content: center;
  gap: var(--sp-6); margin-bottom: var(--sp-4);
}
.match-team { display: flex; flex-direction: column; align-items: center; gap: var(--sp-3); }
.flag-svg {
  border-radius: var(--radius-sm);
  border: 1.5px solid rgba(255,255,255,0.25);
  display: block;
  filter: drop-shadow(0 3px 8px rgba(0,0,0,0.35));
}
.match-team-name {
  font-family: var(--font-display); font-size: var(--text-sm);
  font-weight: 800; color: var(--white);
  text-transform: uppercase; letter-spacing: 0.05em;
  text-shadow: 0 1px 4px rgba(0,0,0,0.5);
}
.vs-badge {
  width: 46px; height: 46px; flex-shrink: 0;
  background: var(--red); border: 2px solid var(--yellow);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: var(--text-xs);
  font-weight: 900; color: var(--white); letter-spacing: 0.05em;
}
.vs-badge--gold { background: var(--yellow-dark); border-color: var(--white); }
.vs-badge--red  { background: var(--red-dark); border-color: var(--yellow); }
.match-meta { font-size: var(--text-xs); color: rgba(255,255,255,0.60); letter-spacing: 0.03em; }

/* === Form card === */
.form-card {
  background: var(--surface);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.form-card-top { height: 6px; flex-shrink: 0; }
.blue-top   { background: linear-gradient(90deg, var(--blue) 33%, var(--yellow) 33% 66%, var(--red) 66%); }
.gold-top   { background: linear-gradient(90deg, var(--yellow) 33%, var(--blue) 33% 66%, var(--red) 66%); }
.red-top    { background: linear-gradient(90deg, var(--red) 33%, var(--yellow) 33% 66%, var(--blue) 66%); }

.form-card-body { padding: var(--sp-6) var(--sp-8) var(--sp-8); flex: 1; }

.form-title {
  font-family: var(--font-display); font-size: var(--text-xl);
  font-weight: 900; color: var(--text); letter-spacing: -0.02em;
  margin-bottom: var(--sp-1);
}
.form-subtitle { font-size: var(--text-sm); color: var(--muted); margin-bottom: var(--sp-6); }

/* Form fields */
.reg-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
.reg-form .form-group {
  display: flex; flex-direction: column; gap: 4px;
  margin-bottom: var(--sp-4);
}
.reg-form .form-group.full { grid-column: 1 / -1; }

.reg-form label {
  font-size: var(--text-xs); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em; color: var(--text);
}
.req   { color: var(--red); font-weight: 900; }
.opt   { font-size: 0.85em; color: var(--muted); font-weight: 400; text-transform: none; letter-spacing: 0; }
.email-star { color: var(--yellow-dark); font-size: 1.1em; font-weight: 900; margin-left: 2px; }
.field-hint { font-size: var(--text-xs); color: var(--yellow-dark); font-style: italic; }
.ferr { font-size: var(--text-xs); color: var(--red); font-weight: 600; min-height: 1em; }
.req-legend { font-size: var(--text-xs); color: var(--muted); margin-bottom: var(--sp-4); }

.reg-form input,
.reg-form select,
.reg-form textarea {
  width: 100%; padding: 0.68rem 0.9rem;
  font-family: var(--font-body); font-size: var(--text-sm);
  color: var(--text); background: var(--off-white);
  border: 1.5px solid var(--border); border-radius: var(--radius-md);
  outline: none;
  transition: border-color var(--transition), box-shadow var(--transition), background var(--transition);
}
.reg-form input:focus,
.reg-form select:focus,
.reg-form textarea:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(0,127,255,0.13);
  background: var(--white);
}
.reg-form input::placeholder,
.reg-form textarea::placeholder { color: #a0aec0; }
.reg-form textarea { resize: vertical; min-height: 80px; }
.reg-form input.invalid,
.reg-form select.invalid,
.reg-form textarea.invalid {
  border-color: var(--red);
  box-shadow: 0 0 0 3px rgba(206,16,33,0.11);
  background: var(--red-bg);
}

/* Submit buttons */
.submit-btn {
  width: 100%;
  display: flex; align-items: center; justify-content: center;
  padding: var(--sp-4);
  font-family: var(--font-display); font-size: var(--text-base);
  font-weight: 800; border: none; border-radius: var(--radius-lg);
  cursor: pointer;
  transition: background var(--transition), box-shadow var(--transition), transform var(--transition);
}
.submit-btn:active { transform: scale(0.98); }
.submit-btn--blue {
  background: var(--blue); color: var(--white);
  box-shadow: 0 4px 16px rgba(0,127,255,0.30);
}
.submit-btn--blue:hover { background: var(--blue-dark); box-shadow: 0 6px 24px rgba(0,127,255,0.40); }
.submit-btn--gold {
  background: var(--yellow); color: var(--dark);
  box-shadow: 0 4px 16px rgba(196,169,0,0.30);
}
.submit-btn--gold:hover { background: var(--yellow-dark); box-shadow: 0 6px 24px rgba(196,169,0,0.40); }
.submit-btn--red {
  background: var(--red); color: var(--white);
  box-shadow: 0 4px 16px rgba(206,16,33,0.30);
}
.submit-btn--red:hover { background: var(--red-dark); box-shadow: 0 6px 24px rgba(206,16,33,0.40); }

/* Success state */
.form-success {
  display: none; text-align: center;
  padding: var(--sp-10) var(--sp-4);
}
.success-icon { font-size: 3rem; margin-bottom: var(--sp-4); }
.form-success h3 {
  font-family: var(--font-display); font-size: var(--text-xl);
  font-weight: 900; color: var(--text); margin-bottom: var(--sp-3);
}
.form-success p { font-size: var(--text-base); color: var(--muted); line-height: 1.6; }

/* === Footer === */
.site-footer { margin-top: auto; background: rgba(0,8,30,0.88); backdrop-filter: blur(10px); }
.footer-stripe { display: flex; height: 5px; }
.fs-blue  { flex: 1; background: var(--blue); }
.fs-yellow{ flex: 1; background: var(--yellow); }
.fs-red   { flex: 1; background: var(--red); }
.footer-inner {
  max-width: 1100px; margin: 0 auto;
  padding: var(--sp-6) var(--sp-8);
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: var(--sp-4);
}
.footer-logo-wrap { display: flex; align-items: center; gap: var(--sp-3); }
.footer-site-name { font-family: var(--font-display); font-size: var(--text-sm); font-weight: 800; color: var(--white); }
.footer-email { font-size: var(--text-xs); color: rgba(255,255,255,0.65); text-decoration: none; }
.footer-email:hover { color: var(--yellow); }
.footer-copy { font-size: var(--text-xs); color: rgba(255,255,255,0.45); }

/* === Fade-in === */
.fade-in { opacity:0; transform: translateY(16px); transition: opacity 0.55s cubic-bezier(0.16,1,0.3,1), transform 0.55s cubic-bezier(0.16,1,0.3,1); }
.fade-in.visible { opacity:1; transform:none; }

/* === Responsive === */
@media (max-width: 900px) {
  .game-section-inner,
  .game-section-inner--rev {
    grid-template-columns: 1fr;
    direction: ltr;
  }
  .match-card { position: static; }
  .game-section { padding: var(--sp-8) var(--sp-4); }
  .guarantee-banner { margin: 0 var(--sp-4) var(--sp-2); }
  .hero-section { padding: var(--sp-12) var(--sp-4) var(--sp-8); }
}
@media (max-width: 600px) {
  .site-header { padding: var(--sp-3) var(--sp-4); }
  .header-contact { display: none; }
  .reg-form .form-row { grid-template-columns: 1fr; }
  .form-card-body { padding: var(--sp-5) var(--sp-4); }
  .hero-nav { flex-direction: column; align-items: center; }
  .hero-nav-btn { width: 100%; max-width: 320px; text-align: center; }
  .footer-inner { flex-direction: column; text-align: center; padding: var(--sp-5) var(--sp-4); }
  .match-matchup { gap: var(--sp-4); }
}

/* =============================================
   GOOGLE FORMS EMBED
   ============================================= */
.gform-wrapper {
  width: 100%;
  overflow: hidden;
  border-radius: var(--radius-md);
  background: #fff;
  /* Fixed height so all 3 form cards are the same size */
  height: 1860px;
}

.gform-wrapper iframe {
  display: block;
  width: 100%;
  height: 100%;
  min-width: 0;
  border: none;
  border-radius: var(--radius-md);
}

/* =============================================
   REGISTRATION PAUSE NOTICE BANNER
   ============================================= */
.pause-notice {
  background: linear-gradient(135deg, #7b0010 0%, #ce1021 50%, #a8001b 100%);
  border-top: 4px solid var(--yellow);
  border-bottom: 4px solid var(--yellow);
  padding: var(--sp-8) var(--sp-6);
  position: relative;
  z-index: 10;
}

.pause-notice-inner {
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  align-items: flex-start;
  gap: var(--sp-6);
}

.pause-icon {
  font-size: 2.5rem;
  flex-shrink: 0;
  line-height: 1;
  margin-top: 2px;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,0.3));
}

.pause-content {
  flex: 1;
}

.pause-bilingual {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: var(--sp-6);
  align-items: start;
}

.pause-divider {
  width: 1.5px;
  background: rgba(247,214,24,0.45);
  align-self: stretch;
  min-height: 80px;
  border-radius: 2px;
}

.pause-lang {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--yellow);
  margin-bottom: var(--sp-2);
  opacity: 0.9;
}

.pause-msg {
  font-size: var(--text-base);
  font-weight: 600;
  color: #fff;
  line-height: 1.5;
  margin-bottom: var(--sp-2);
}

.pause-msg strong {
  color: var(--yellow);
  font-weight: 800;
}

.pause-sub {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.82);
  line-height: 1.55;
}

@media (max-width: 640px) {
  .pause-bilingual {
    grid-template-columns: 1fr;
  }
  .pause-divider {
    width: 100%;
    height: 1.5px;
    min-height: unset;
  }
  .pause-notice-inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
}

/* =============================================
   TBD / REGISTRATION PAUSED PLACEHOLDER
   ============================================= */
.tbd-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--sp-10) var(--sp-8);
  border-radius: var(--radius-lg);
  border: 2.5px dashed currentColor;
  gap: var(--sp-4);
  min-height: 340px;
}

.tbd-placeholder--blue {
  background: rgba(0, 127, 255, 0.07);
  border-color: rgba(0, 127, 255, 0.35);
  color: var(--blue);
}
.tbd-placeholder--gold {
  background: rgba(247, 214, 24, 0.08);
  border-color: rgba(196, 169, 0, 0.45);
  color: #a08800;
}
.tbd-placeholder--red {
  background: rgba(206, 16, 33, 0.07);
  border-color: rgba(206, 16, 33, 0.35);
  color: var(--red);
}

.tbd-icon {
  font-size: 2.8rem;
  line-height: 1;
  opacity: 0.75;
}

.tbd-label {
  font-family: var(--font-display);
  font-size: 3rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  line-height: 1;
  opacity: 0.9;
}

.tbd-msg-fr,
.tbd-msg-en {
  font-size: var(--text-base);
  color: var(--text);
  line-height: 1.55;
  max-width: 340px;
  margin: 0;
}

.tbd-msg-fr strong,
.tbd-msg-en strong {
  font-weight: 700;
}

.tbd-placeholder--blue .tbd-msg-fr strong,
.tbd-placeholder--blue .tbd-msg-en strong { color: var(--blue); }
.tbd-placeholder--gold .tbd-msg-fr strong,
.tbd-placeholder--gold .tbd-msg-en strong { color: #a08800; }
.tbd-placeholder--red .tbd-msg-fr strong,
.tbd-placeholder--red .tbd-msg-en strong  { color: var(--red); }

.tbd-msg-fr {
  padding-bottom: var(--sp-2);
  border-bottom: 1px solid rgba(0,0,0,0.08);
}

.tbd-notify {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.6;
  max-width: 340px;
  margin: 0;
}
