:root {
  --primary: #0056b3;
  --primary-light: #007BFF;
  --accent: #FFD700;
  --bg: #f9fafb;
  --text: #333;
  --radius: 6px;
  --spacing: 1rem;
  --max-width: 600px;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: "Helvetica Neue", Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  /* Achtergrondafbeelding */
  background: url("../images/background.png") no-repeat center center;
  background-size: cover;
  
  /* Zorg dat de body altijd minimaal volle hoogte heeft */
  min-height: 100vh;
  margin: 0;
}

header {
  background: #fff;
  padding: var(--spacing);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--spacing);
  flex-wrap: wrap;
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}

/* Overlay onder main voor leesbaarheid */
main {
  position: relative;
  z-index: 1;
  margin: 2rem auto;
  padding: 0 var(--spacing);
  max-width: var(--max-width);
}

form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing);
  background: #fff;
  padding: var(--spacing);
  border-radius: var(--radius);
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}

form label {
  display: flex;
  flex-direction: column;
  font-weight: bold;
}

form input {
  margin-top: 0.5rem;
  padding: 0.75rem;
  border: 1px solid #ccc;
  border-radius: var(--radius);
}

form button {
  grid-column: 1 / -1;
  padding: 0.75rem;
  background: var(--primary);
  color: #fff;
  font-size: 1rem;
  border: none;
  border-radius: var(--radius);
  cursor: pointer;
  transition: background 0.2s;
}

form button:hover {
  background: var(--primary-light);
}

#message {
  text-align: center;
  margin-top: var(--spacing);
  font-size: 1rem;
}

form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing);
  background: #fff;
  padding: var(--spacing);
  border-radius: var(--radius);
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}

/* Mobile responsiveness voor het RSVP-formulier (index.php) */
@media (max-width: 600px) {
  /* Zet de twee-koloms grid om naar één kolom */
  form#rsvp {
    grid-template-columns: 1fr !important;
    padding: var(--spacing) 0.5rem;
  }

  /* Zorg dat alle labels en inputs full-width zijn */
  form#rsvp label,
  form#rsvp button {
    grid-column: 1 / -1;
  }

  form#rsvp input {
    width: 100%;
    box-sizing: border-box;
  }

  /* Verklein de typography iets voor betere leesbaarheid op klein scherm */
  form#rsvp label {
    font-size: 0.95rem;
  }

  /* Eventueel: maak de knop wat meer tappable */
  form#rsvp button {
    padding: 1rem;
  }
}

/* Utility voor volle breedte */
form .full {
  grid-column: 1 / -1;
}

/* CSS van retrieve.php */
/* Mobile responsiveness voor retrieve-form */
@media (max-width: 600px) {
  .retrieve-form {
    grid-template-columns: 1fr !important; /* één kolom */
    padding: var(--spacing) 0.5rem;         /* iets minder padding */
  }

  .retrieve-form label,
  .retrieve-form .cf-turnstile.full,
  .retrieve-form button.full {
    grid-column: 1 / -1;                    /* zorg dat ze full-width lopen */
  }

  .retrieve-form input,
  .retrieve-form button.full {
    width: 100%;                            /* inputs en knop full-width */
    box-sizing: border-box;
  }

  /* Ticket-link buttons onder het formulier */
  .ticket-link a {
    display: block;
    margin: 0.5rem auto;
    width: 80%;
    max-width: 300px;
  }
}

.retrieve-form,
.login-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing);
}

.retrieve-form .full,
.login-form .full {
  grid-column: 1 / -1;
}

.retrieve-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing);
  background: #fff;
  padding: var(--spacing);
  border-radius: var(--radius);
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);
  max-width: var(--max-width);
  margin: var(--spacing) auto;
}
.retrieve-form .full {
  grid-column: 1 / -1;
}
.retrieve-form .instruct {
  font-style: italic;
  color: #555;
  margin: 0;
}
.retrieve-form button {
  padding: 0.75rem;
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: var(--radius);
  cursor: pointer;
  transition: background 0.2s;
}
.retrieve-form button:hover {
  background: var(--primary-light);
}
.message {
  max-width: var(--max-width);
  margin: var(--spacing) auto;
  text-align: center;
  color: <?= strpos($message, 'verzonden') !== false ? '#2e7d32' : '#d32f2f' ?>;
}
.ticket-link {
  max-width: var(--max-width);
  margin: var(--spacing) auto;
  text-align: center;
}
.ticket-link a {
  display: inline-block;
  margin: 0.5rem;
  padding: 0.5rem 1rem;
  background: var(--primary);
  color: #fff;
  text-decoration: none;
  border-radius: var(--radius);
}

/* CSS van ticket.php */
.success-banner {
  background: #e6ffed;
  border: 1px solid #a5d6a7;
  color: #2e7d32;
  padding: 1rem;
  border-radius: 4px;
  max-width: var(--max-width);
  margin: 2rem auto 1rem;
  text-align: center;
  font-weight: bold;
}
.ticket-card {
  background: #fff;
  padding: var(--spacing);
  border-radius: var(--radius);
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);
  max-width: var(--max-width);
  margin: 0 auto;
  text-align: center;
}
.ticket-company {
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 0.25rem;
}
.ticket-name {
  font-size: 1.5rem;
  margin-bottom: 1rem;
}

/* Ticket-pagina stijlen */
.ticket-details p {
  margin: 0.3rem 0;
}
/* QR-code */
.ticket-qr {
  max-width: 200px;
  margin: 0.5rem auto;
}
/* Partners-logo’s */
.ticket-partners {
  display: flex;
  justify-content: center;
  gap: 1rem;
  margin-top: 0.5rem;
}
.partner-logo {
  max-height: 75px;
  width: auto;
}
/* Alleen in de ticket-pagina: partner-logo’s grijs maken */
.ticket-partners .partner-logo {
  filter: grayscale(100%) brightness(60%);
}

/* Specifieke styling voor de Turnstile container */
.cf-turnstile {
  grid-column: 1 / -1;        /* Over beide kolommen */
  margin: var(--spacing) 0;   /* Ruimte boven/onder */
}

/* Zorg dat het formulier altijd in twee kolommen blijft, met .full-elementen over de volle breedte */
.rsvp-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing);
}
.rsvp-form .full {
  grid-column: 1 / -1;
}

/* Labels en inputs netjes in hun cell houden */
.rsvp-form label {
  display: flex;
  flex-direction: column;
}

/* Zorg dat foutboodschappen full-width zijn en niet de layout breken */
.error-banner,
.error-text {
  grid-column: 1 / -1;
}

/* Specifiek voor error-banner direct onder het form-element */
.error-banner {
  margin-bottom: var(--spacing);
}
.error-text {
  display: block;
  color: #b00020;
  font-size: 0.875rem;
  margin-top: 0.25rem;
}
.name-row, .contact-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing);
}

/* Zorg dat inputs en labels mooi in hun cell blijven */
.retrieve-form label,
.login-form label {
  display: flex;
  flex-direction: column;
}

/* Scherm­weergave: event-logo styling */
.event-logo {
  display: block;
  max-width: 150px;    /* maximaal 150px breed */
  width: auto;         /* breedte automatisch aanpassen */
  height: auto;        /* hoogte automatisch aanpassen */
  margin: 0 auto 1rem; /* gecentreerd met marge onder */
}

.event-logo-header {
  display: block;
  max-width: 150px;    /* maximaal 250px breed */
  width: auto;         /* breedte automatisch aanpassen */
  height: auto;        /* hoogte automatisch aanpassen */
}

/* Footer met partner-logo’s */
.partners-footer {
  text-align: center;
  margin: 2rem auto;
  padding: 1rem 0 2rem;
  border-top: 1px solid #e0e0e0;
  color: #fff;
  font-size: 0.9rem;
}

.partners-footer p {
  margin: 0 0 0.5rem;
}

.partner-logos {
  display: inline-flex;
  gap: 1.5rem;
}

.partner-logo {
  max-height: 75px;
  width: auto;
  display: block;
}

/* Print­weergave */
@media print {
  /* Verberg alle elementen behalve de ticket-kaart */
  body * {
    visibility: hidden;
  }

  /* Maak de ticket-kaart en zijn kinderen zichtbaar */
  .ticket-card,
  .ticket-card * {
    visibility: visible;
  }

  /* Positioneer de ticket-kaart exact in het midden van de pagina */
  .ticket-card {
    position: fixed !important;   /* fixed i.p.v. absolute */
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;

    /* Verwijder marges en beperkingen */
    margin: 0 !important;
    width: auto !important;
    max-width: 80% !important;     /* of kies een passend percentage */
    box-shadow: none !important;
    border: none !important;
    background: #fff !important;
  }

  /* Verberg de print-knop */
  .print-button {
    display: none !important;
  }
}